sql 分组后重复数据取时间最新的一条记录
1.取时间最新的记录 不分组有重复(多条CreateTime一样的都是最新记录)
select * from test t where pid in ( select PId from Test t where time=(select max(time) from Test t1 where t1.PId=t.PId) group by Pid ) and time=(select max(time) from Test t1 where t1.PId=t.PId)
2.分组后取时间最新的记录
SELECT max(Id)/*注意Id必须使用聚合函数Max;*/ , Pid, MAX(Time) as MaxTime FROM Test GROUP BY pid
3.如果Id是uuid类型无法使用max(id)的解决办法(使用开窗函数)
select * from ( select row_number() over(partition by [Pid] order by [Time] desc /*降序是为了where KeyId=1 (1是固定值第一条),如果升序由于不知道每组多少条where中KeyId就无法过滤了*/ ) as KeyId,* from Test ) d where KeyId=1
From:https://www.cnblogs.com/xuejianxiyang/p/11980908.html
DROP TABLE IF EXISTS ##tmpTable; --存在表则删除
select CONVERT(varchar(100), @time, 23) --取datetime的年月日 2019-12-17
select CONVERT(varchar(100), GETDATE(), 24) --取datetime的时间 10:57:47
作者:xuejianxiyang
出处:http://xuejianxiyang.cnblogs.com
关于作者:Heaven helps those who help themselves.
本文版权归原作者和博客园共有,欢迎转载,但未经原作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。