Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> mysql php sql запрос
timur.ya  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 5
Пользователь №: 43471
На форуме: 2 месяца, 2 дня
Карма:




user posted image
user posted image
Как получить sql или php запросом вот такое?
id_from
id_to
name_from
read_mes - 1 = Прочитано, 0 непрочитано

Т.е. здесь нужно сделать выборку уникальных
1) id_from -> у них взять Имя(name_from)
2) сколько всего read_mes (И прочитанных и непрочитанных)
3) Сколько всего read_mes(Непрочитанных)
Я не настолько знаю sql , но если это нельзя сделать через выборку sql не несколько запросами , а одним , А) то и времени на запрос много будет,
а если просто всю выборку брать , а потом через php уникальные значения каждого массива, то это геморойно,, и опять таки затратно.
Может кто сможет помочь вот такой запрос составить, у меня мозгов хватает только на всякие distinct, count('read_mes')

Это сообщение отредактировал timur.ya - 7.10.2016 - 09:33
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Kusss  
Дата
Цитировать сообщение

Пользователь сейчас на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1357
Пользователь №: 28976
На форуме: 5 лет, 4 месяца, 10 дней
Карма: 77




А зачем писать имя отправителя в таблицу, если есть id ?
как-то так можно, но я не проверял. Если не заработает напишите - создам таблицу у себя и сделаем рабочий
// `user` - таблица с пользователями, из которой берется имя отправителя
// $user_id = адресат

$sql = "
SELECT
m.id_from, COUNT(m.id) AS all,
(SELECT COUNT(id) FROM `message` WHERE id_from = m.id_from AND read_mes IS NULL) AS `new`,
u.name
FROM
`message` AS m
INNER JOIN
`user` AS u ON u.id = m.id_from
WHERE
m.id_to =
$user_id
GROUP BY
m.id_from
"
;
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
timur.ya  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 5
Пользователь №: 43471
На форуме: 2 месяца, 2 дня
Карма:




Цитата (Kusss @ 7.10.2016 - 10:07)
А зачем писать имя отправителя в таблицу, если есть id ?
как-то так можно, но я не проверял. Если не заработает напишите - создам таблицу у себя и сделаем рабочий
// `user` - таблица с пользователями, из которой берется имя отправителя
// $user_id = адресат

$sql = "
SELECT
m.id_from, COUNT(m.id) AS all,
(SELECT COUNT(id) FROM `message` WHERE id_from = m.id_from AND read_mes IS NULL) AS `new`,
u.name
FROM
`message` AS m
INNER JOIN
`user` AS u ON u.id = m.id_from
WHERE
m.id_to =
$user_id
GROUP BY
m.id_from
"
;

Вроде все отлично работает, чуть чуть исправил и все хорошо работает. Мучался пол ночи над этим ((
Спасибо большое!
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Kusss  
Дата
Цитировать сообщение

Пользователь сейчас на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1357
Пользователь №: 28976
На форуме: 5 лет, 4 месяца, 10 дней
Карма: 77




не забудьте установить индексы на id_from и id_to
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса