我有 2 个表 -- 表 1 是主文件,表 2 是活动文件。
关系是一对多。
我正在生成一份报告,我只想返回每个主文件行,仅连接到相关主 ID 的最后一个活动行。
我不确定如何请求最后一个活动行。我下面的代码返回每个活动行(理所当然)。
谢谢你的帮助。
SELECT *
FROM master_file AS master
INNER JOIN activity_file AS activity ON activity.id = master.id
ORDER BY master.display_name
活动文件有一个名为 entry_date
的列。它是记录每个活动的日期和时间戳。我只想选择最后一个entry_date
.
例如:
表2 - 活动如下所示
ID ACTIVITY ENTRY_DATE
1 Update 2012-08-01 09:00:00
1 Edit 2012-08-01 13:45:15
3 Create 2012-07-15 10:09:52
3 Delete 2012-07-22 23:02:00
3 Add 2012-08-05 04:33:00
4 Edit 2012-08-03 15:12:00
的一种标准方法是创建一个内联视图,该视图查找每个ID的最后entry_date。
SELECT *
FROM master_file AS master
LEFT JOIN activity_file AS activity ON activity.id = master.id
LEFT JOIN (select id , max(entry_date) entry_date
From activity_file
group by id) last_activity
ON activity_file.id = last_activity.id
and activity_file.entry_date= last_activity.entry_date
ORDER BY master.display_name
这种方法的一个问题是,对于给定的 id,您可能有多个带有 max(entry_date) 的记录。您要么需要让您的业务规则处理此问题(例如,只需为该案例显示多条记录),要么需要找出一个决胜局。你最不想做的就是让它是非确定性的