sql-запрос, вывод диалогов оптимизировать

php MySQL базы данных sql

есть таблица
id | uid | rid | tema | text | datetime | read | udel | rdel

из нее вот таким кодом вытягиваю диалоги (последнее сообщение из каждой переписки)
function dialogs($uid)
{
$res = array();
$result = array();

//возвращает id юзеров с которым общался uid
$rid = select('SELECT uid
FROM message
WHERE rid = '.$uid.'
UNION
SELECT rid
FROM message
WHERE uid = '.$uid);
print_r($rid);
foreach($rid as $k => $v)
foreach($v as $item)
$res[] = select('SELECT *
FROM message
WHERE (udel=0 OR udel=false)
AND (uid='.$uid.' AND rid='.$item.')
OR (uid='.$item.' AND rid='.$uid.')
ORDER BY datetime DESC
LIMIT 1');
foreach($res as $k => $v)
$result[] = $v[0];

return $result;
}
как оптимизировать в один sql-запрос? думаю о вложеных запросах, но пока не получается

Примечание:
rid = uid ?
не выберется ни одной записи, получается у отправителя и получателя одинаковые ид, он сам себе написал?)

Примечание:
неа, не подошло(
Ответы:
SELECT
   * FROM table
WHERE rid = uid ORDER BY  datetime DESC LIMIT 1
Ну заменить там MAX(id) на MAX(uid,'-',rid,'-',id) вот и будет одним запросом, только оптимизацией тут совсем не пахнет (запрос "тяжелый")


12 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.