Задать вопрос
@Caman
Разработка

Объединение таблиц, LIMIT 1

Здравствуйте. Подскажите, как правильно оформить SQL запрос, чтобы получить единственное и последнее значение во второй таблице?

SELECT
	t1.id,
	t1.title,
	t2.user AS `last_user`,
	t2.datetime AS `last_date`
FROM
	`topics` AS t1 INNER JOIN
	`comments` AS t2 ON (t2.id_topic = t1.id)
GROUP BY
	t1.id DESC


Я хочу получить последний комментарий, как если бы это выглядело так:

SELECT t2.datetime, t2.user FROM `comments` AS t2 WHERE t2.id_topic = t1.id ORDER BY t2.id DESC LIMIT 1
  • Вопрос задан
  • 3026 просмотров
Подписаться 4 Оценить Комментировать
Решения вопроса 1
ivnik
@ivnik
Например так:

select t1.*, c.user as `last_user`, c.datetime as `last_date` from topics as t1 inner join (select id_topic, max(id) max_id from comments c1 group by id_topic) t2 on (t2.id_topic = t1.id) inner join comments c on (c.id = t2.max_id);

Использовать ORDER BY для поиска максимального элемента не очень хорошая идея (хотя вроде оптимизатор mysql при использовании ORDER BY и LIMIT понимает, что сортировать не нужно)
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Igogo2012
@Igogo2012
По идее можно так:
SELECT t1.id,
    t1.title,
    t2.user AS `last_user`,
    t2.datetime AS `last_date` 
FROM `comments` t2, topics t1  
WHERE t1.id=t2.id_topic 
ORDER BY t2.id DESC 
LIMIT 1
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы