|
|
|
| Помогите пожалуйста произвести выборку данных из двух таблиц
Пользователи
ID | Name
---------------
12| Семен
13| Коля
14| Петя
Сообщения
message_id, user_id, date_sent
-----------------------------------------------
1 | 12 | 07.10.2009
2 | 12 | 08.10.2009
3 | 13 | 07.10.2009
Помогите пожалуйста выбрать имена всех пользователей и дату последнего отправленнгого им сообщения. Тоесть у Семена последнее сообщение было восьмого числа, у Коли седьмого, а для Пети графу даты оставить пустую, но его имя тоже надо выбрать.
Заранее благодарю. | |
|
|
|
|
|
|
|
для: _Efim_
(08.10.2009 в 14:18)
| | Придётся сменить формат даты на '2009-10-07' и присвоить полю date_sent тип 'date'.
<?php
$arr = array('12','13','14'); // Массив с нужными id-пользователей
for($z=0; $z < count($arr); $z++)
{
$est = mysql_query("SELECT * FROM `polzovateli` WHERE `ID` = '".$arr[$z]."'");
if($et=mysql_fetch_array($est))
{
echo $et['Name']; // Выводим имя
$est2 = mysql_query("SELECT * FROM `soobsheniya` WHERE `user_id` = '".$et['ID']."' ORDER BY `date_sent` DESC");
if($et2=mysql_fetch_array($est2))
{
echo ' '.$et2['date_sent'].'<br>'; // Выводим дату
}
}
}
?>
|
| |
|
|
|
|
|
|
|
для: Diplex
(08.10.2009 в 23:55)
| | Формат даты - да, нужно сменить.
А в остальном, вопрос решается одним агрегатным LEFT-JOIN запросом. | |
|
|
|
|
|
|
|
для: Trianon
(09.10.2009 в 00:03)
| | Но этот способ имеет право на жизнь? :) | |
|
|
|
|
|
|
|
для: Diplex
(09.10.2009 в 00:18)
| | Покажите пожалуйста какой запрос получится ?
Дело в том, что при Joinе, Семен будет находится в списке дважды, из за того, что у него два сообщения.
При Left Join семен все равно там оказывается дважды, и как и нужно, показываются еще по одному разу Коля и Петя.
SELECT DISTINCT и SELECT UNIQUE мне не помогли.
GROUP BY Name ORDER BY Date DESC тоже.
Подскажите пожалуйста правильный запрос. | |
|
|
|
|
|
|
|
для: _Efim_
(09.10.2009 в 12:35)
| | группирующий запрос предполагает (по стандарту - даже обязывает) применять агрегатные функции.
В данном случае логика требует функцию MAX() | |
|
|
|
|
|
|
|
для: Trianon
(09.10.2009 в 13:31)
| | Покажите пожалуйста какой в итоге получится запрос.
(Поле дат имеет тип Date) | |
|
|
|
|
|
|
|
для: _Efim_
(10.10.2009 в 13:12)
| | Показывайте Ваш вариант запроса - будем разбирать ошибки. | |
|
|
|
|
|
|
|
для: Trianon
(11.10.2009 в 09:50)
| | SELECT DISTINCT(u.name), m.date_sent FROM users u
LEFT JOIN messages m ON (m.user_id = u.id )
ORDER BY m.date_sent DESC; | |
|
|
|
|
|
|
|
для: _Efim_
(11.10.2009 в 10:47)
| | Как-то здесь не видно, что Вы хотите получить наибольшее время ( MAX(m.date_sent) ) для каждого пользователя ( GROUP BY u.id )
А DISTINCT - лишний, и ORDER BY тоже | |
|
|
|
|
|
|
|
для: Diplex
(09.10.2009 в 00:18)
| | Нет. | |
|
|
|
|
|
|
|
для: Trianon
(09.10.2009 в 15:07)
| | Подскажите пожалуйста какой в итоге запрос выйдет. У меня все время получается в результате два Семена | |
|
|
|