如何仅返回日期字段上的最新记录,分为两部分
Posted
技术标签:
【中文标题】如何仅返回日期字段上的最新记录,分为两部分【英文标题】:How do I return only the most recent record on a date field split into two 【发布时间】:2020-11-19 12:08:36 【问题描述】:情景:A 人在两年内参加了 3 次 B 考试。该人将有三个条目。但是,我需要编写一个查询来告诉我参加过考试的人数(只有一个,最新的考试)。问题在于我有一个标记为 Test_Month (xx) 和 Test_year(xx) 的列。
我需要什么:我需要能够使用最近的测试月份和年份进行测试,基本上是他们最近参加的测试。 (例如(见下图)我需要,只有2/20的记录。)
我不知道如何根据单独的列 test_Month 和 test_year 在他们参加的最后一次测试中仅检索每人一条记录。
【问题讨论】:
【参考方案1】:你可以使用窗口函数:
select *
from (
select
t.*,
row_number() over(
partition last_name, firt_name
order by test_year desc, test_month desc
) rn
from mytable t
) t
where rn = 1
【讨论】:
那行得通,但只适用于这一年,我想知道我如何才能连续两年做到这一点,所以,如果他们参加了 3 次考试,2019 年两次,2020 年一次,我需要 2020 年记录。但是我从这个查询中学到了很多东西,非常感谢您以上是关于如何仅返回日期字段上的最新记录,分为两部分的主要内容,如果未能解决你的问题,请参考以下文章