簡體   English   中英

從基於另一個表的表中選擇條目

[英]Selecting entries from a table based on another table

我正在使用帶有SQLITE3后端的論壇。

我的目標是找到最近的帖子下的最近20個主題。 我嘗試了這個:

SELECT * FROM Topics INNER JOIN Posts ON Topics.ID = Posts.TopicID ORDER BY Posts.Modified DESC LIMIT 20

這並不是我想要的,因為它每次有新帖子發布時都會重復相同的主題。 我只想要一個話題。

您必須為每個主題獲取一個最新的帖子,然后按以下順序排序:

SELECT Topics.*,
       (SELECT MAX(Modified)
        FROM Posts
        WHERE TopicID = Topics.ID
       ) AS LastModified
FROM Topics
ORDER BY LastModified DESC
LIMIT 20

聯接也可以這樣做:

SELECT Topics.*,
       MAX(Posts.Modified)
FROM Topics
JOIN Posts ON Topics.ID = Posts.TopicID
GROUP BY Topics.ID
ORDER BY MAX(Posts.Modified) DESC
LIMIT 20

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM