MySQL 查询加入对主题的最后评论
MySQL Query join last comment to topic
我有一个话题topic_commentstable。我想加入他们。
+------------+ +------------+
| Topic | | Comments |
+------------+ +------------+
| id | | parent_id |
| title | | content |
| createdate | | createdate |
| content | | creator_id |
+------------+ +------------+
连接在 topic.id = topic_comments.parent_id
。我想显示带有最新评论的主题,并按最新评论 createdate
排序。并且不显示重复的主题。谁能帮帮我?
到目前为止我有这个:
select p.id, p.title, p.createdate, p.content, p.int_0 as reacties_total, p.char_1 as prio, p.char_0 as status, r.createdate as r_createdate, r.creator_id as r_creator_id, r.content as r_content
from pages p, topic_reacties r
where r.parent_id = p.id
and p.parent_id = ' . $this->id . '
order by p.int_2 desc
然而,这不会显示没有评论的主题。它只有 returns 个主题有反应。
SELECT title,content,max(createdate) as createdate
FROM topic
left join comments
on topic.id=comments.parent_id
group by title
order by createdate desc;
您是要显示最新评论的主题并按评论排序还是每个主题是否有评论?这是两个不同的要求。
如果您想显示带有最新评论的主题,请像您一样使用连接(除了请去掉陈旧的语法),但在 on
子句中添加更多细节:
select p.id, p.title, p.createdate, p.content,
p.int_0 as reacties_total, p.char_1 as prio,
p.char_0 as status, r.createdate as r_createdate,
r.creator_id as r_creator_id, r.content as r_content
from pages p
join topic_reacties r
on r.parent_id = p.id
and r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id )
order by r.createdate;
不要让子查询吓到你。测试它,您会看到令人印象深刻的效率——如果 createdate
列被索引。
如果您想要所有 个主题是否有评论,但只有最新的评论,请使用外部联接。您仍会使用相同的子查询,但某些 DBMS 不允许在外连接的 on
子句中使用子查询。例如甲骨文。我不确定 MySQL。无论如何,为了安全起见,我总是将它移到 where
子句中。 (我处理很多不同的 DBMS。)
但是,当您在 where
子句中检查外部联接的外部 table 时,您可以将输出转换为与内部联接相同的输出。所以你得用点小技巧了。
select p.id, p.title, p.createdate, p.content,
p.int_0 as reacties_total, p.char_1 as prio,
p.char_0 as status, r.createdate as r_createdate,
r.creator_id as r_creator_id, r.content as r_content
from pages p
left join topic_reacties r
on r.parent_id = p.id
where (r.parent_id is null
or r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id ))
order by r.createdate;
请注意,我在 where
检查周围放置了 parentheses/brackets,但正如所写的那样,它们并不是绝对必要的。但是,如果您添加任何其他检查,则需要将它们放在括号之外。
where (r.parent_id is null
or r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id ))
and p.ID = :SomeID
查看 SQL Fiddle
我有一个话题topic_commentstable。我想加入他们。
+------------+ +------------+
| Topic | | Comments |
+------------+ +------------+
| id | | parent_id |
| title | | content |
| createdate | | createdate |
| content | | creator_id |
+------------+ +------------+
连接在 topic.id = topic_comments.parent_id
。我想显示带有最新评论的主题,并按最新评论 createdate
排序。并且不显示重复的主题。谁能帮帮我?
到目前为止我有这个:
select p.id, p.title, p.createdate, p.content, p.int_0 as reacties_total, p.char_1 as prio, p.char_0 as status, r.createdate as r_createdate, r.creator_id as r_creator_id, r.content as r_content
from pages p, topic_reacties r
where r.parent_id = p.id
and p.parent_id = ' . $this->id . '
order by p.int_2 desc
然而,这不会显示没有评论的主题。它只有 returns 个主题有反应。
SELECT title,content,max(createdate) as createdate
FROM topic
left join comments
on topic.id=comments.parent_id
group by title
order by createdate desc;
您是要显示最新评论的主题并按评论排序还是每个主题是否有评论?这是两个不同的要求。
如果您想显示带有最新评论的主题,请像您一样使用连接(除了请去掉陈旧的语法),但在 on
子句中添加更多细节:
select p.id, p.title, p.createdate, p.content,
p.int_0 as reacties_total, p.char_1 as prio,
p.char_0 as status, r.createdate as r_createdate,
r.creator_id as r_creator_id, r.content as r_content
from pages p
join topic_reacties r
on r.parent_id = p.id
and r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id )
order by r.createdate;
不要让子查询吓到你。测试它,您会看到令人印象深刻的效率——如果 createdate
列被索引。
如果您想要所有 个主题是否有评论,但只有最新的评论,请使用外部联接。您仍会使用相同的子查询,但某些 DBMS 不允许在外连接的 on
子句中使用子查询。例如甲骨文。我不确定 MySQL。无论如何,为了安全起见,我总是将它移到 where
子句中。 (我处理很多不同的 DBMS。)
但是,当您在 where
子句中检查外部联接的外部 table 时,您可以将输出转换为与内部联接相同的输出。所以你得用点小技巧了。
select p.id, p.title, p.createdate, p.content,
p.int_0 as reacties_total, p.char_1 as prio,
p.char_0 as status, r.createdate as r_createdate,
r.creator_id as r_creator_id, r.content as r_content
from pages p
left join topic_reacties r
on r.parent_id = p.id
where (r.parent_id is null
or r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id ))
order by r.createdate;
请注意,我在 where
检查周围放置了 parentheses/brackets,但正如所写的那样,它们并不是绝对必要的。但是,如果您添加任何其他检查,则需要将它们放在括号之外。
where (r.parent_id is null
or r.createdate =(
select Max( createdate )
from topic_reacties
where parent_id = r.parent_id ))
and p.ID = :SomeID
查看 SQL Fiddle