Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: выборка диалогов

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
jonston
Отправлено: 01 Февраля, 2013 - 07:23:08
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Здравствуйте!Есть 2 таблицы dialogs и massages соединены между собой ключами id dialog_id.Таблица dialogs имеет такие поля 'id', 'key' а таблица messages имеет такие поля: 'id', 'dialog_id', 'text', 'user_from', 'user_to', 'send_time' (Надеюсь предназначение полей понятно).Как выбрать диалоги наподобие как в 'вконтакте', то есть выбрать все диалоги и последнее сообщение этого диалога.Благодарю.


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
DeepVarvar Супермодератор
Отправлено: 01 Февраля, 2013 - 07:37:27
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT d.id, d.`key`, m.`text`, m.user_to
  2.   FROM messages m
  3.   JOIN dialogs d ON d.id = m.dialog_id
  4.   WHERE m.user_to = 22
  5.   GROUP BY d.id
  6.   ORDER BY m.send_time DESC
Не проверял..
 
 Top
jonston
Отправлено: 01 Февраля, 2013 - 08:03:52
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




DeepVarvar пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT d.id, d.`key`, m.`text`, m.user_to
  2.   FROM messages m
  3.   JOIN dialogs d ON d.id = m.dialog_id
  4.   WHERE m.user_to = 22
  5.   GROUP BY d.id
  6.   ORDER BY m.send_time DESC
Не проверял..


Диалог формируется если либо мне написали либо я написал кому то.При выборке выбирается 2 пользователя.Как определить того кто не я?Тупо сравнивать выбранный id или есть решение на sql?

(Отредактировано автором: 01 Февраля, 2013 - 10:04:44)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
EuGen Администратор
Отправлено: 01 Февраля, 2013 - 10:08:49
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




jonston пишет:
Тупо сравнивать выбранный id или есть решение на sql?

Есть. Объединяет обе идеи - добавить к
jonston пишет:
SELECT d.id, d.`key`, m.`text`, m.user_to

Примерно следующее
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT d.id, d.`key`, m.`text`, m.user_to, d.id=22 AS it_is_me


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
jonston
Отправлено: 01 Февраля, 2013 - 10:35:25
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




EuGen пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT d.id, d.`key`, m.`text`, m.user_to, d.id=22 AS it_is_me


Спасибо!Для опыта очень полезно, но не совсем то.Запрос имеет следующий вид:
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2.         SELECT d.*, m.*
  3.         FROM dialogs AS d
  4.         JOIN messages AS m ON d.id = m.dialog_id
  5.         JOIN users AS u1 ON u1.id = m.user_from
  6.         JOIN users AS u2 ON u2.id = m.user_to
  7.         WHERE m.user_to = 7 OR m.user_from = 7
  8.         GROUP BY d.id
  9.         ORDER BY m.send_time DESC
  10.  


Возникают 2 вопроса.Как добавить префикс u1 и u2 (Дабы не лепить u1.id AS u1_id, u1.name AS u1_name, u1.mail AS u1_mail, ..., u2.name AS u2_mail).Второй вопрос как распознать где Я, а где мой СОБЕСЕДНИК?Ведь я могу быть как user_to, так и user_from.
Здорово если запрос выдавал бы записи типа interlocutor_name, me_name и так далее.

(Отредактировано автором: 01 Февраля, 2013 - 10:51:18)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB