MySQL Query将最后一条评论加入主题

时间:2015-03-13 08:25:44

标签: php mysql sql join sql-order-by

我有一个主题和topic_comments表。我想加入他们两个。

+------------+ +------------+
| 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

然而,这并没有显示没有评论的主题。它只返回带有反应的主题。

2 个答案:

答案 0 :(得分:0)

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;

答案 1 :(得分:0)

是否要显示带有最新评论的主题,并按评论或每个主题排序是否有评论?这有两个不同的要求。

如果您想显示带有最新评论的主题,请像使用一样使用联接(除了请丢失古老的语法),但是在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子句中的子查询。例如Oracle。我不确定MySQL。无论如何,为了安全起见,我总是把它移到where条款。 (我处理了很多不同的DBMS。)

但是,在where子句中检查外连接的外表时,可以将输出转换为与内连接相同。所以你必须使用一个小技巧。

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支票周围放置了括号/括号,尽管如上所述,它们并非绝对必要。但是,如果您添加任何其他检查,则需要将它们放在括号之外。

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