SQL Server 2008 中 SQL LEAD 和 LAG 函数的替代品
在 SQL Server 2008 中,LEAD 和 LAG 函数不可用,这可以比较连续行之间的值时会带来挑战。本指南提供了实现类似功能的替代方法。
问题陈述
目标是识别当前行的 StatusId 为 1 的行以及后续行StatusId 为 6,时间在同一分钟内。例如,在提供的表中,我们要检索行 Id 6,因为行 Id 6 的 StatusId 为 1,行 Id 7 的 StatusId 为 6,并且它们的时间基本相同:2014-02-19 06: 11.
解决方案1:自加入
一个方法是自连接:
select t.* from table t join table tnext on t.id = tnext.id - 1 and t.StatusId = 1 and tnext.StatusId = 6 and datediff(second, t.MinStartTime, tnext.MinStartTime) < 60;
此查询返回当前行的 Id 比下一行的 Id 小 1 的行,当前行的 StatusId 为 1,下一行的 StatusId 为 6。下一行,且时间差在 60 秒以内。
解决方案 2:相同日历分钟
如果你要求时间在同一个日历分钟内,你可以修改查询如下:
select t.* from table t join table tnext on t.id = tnext.id - 1 and t.StatusId = 1 and tnext.StatusId = 6 and datediff(second, t.MinStartTime, tnext.MinStartTime) < 60 and datepart(minute, t.MinStartTime) = datepart(minute, tnext.MinStartTime);
这个查询另外检查两个时间是否在同一日历分钟内行相等,确保它们属于同一日历分钟。
以上是如何在 SQL Server 2008 中复制 SQL LEAD 和 LAG 功能?的详细内容。更多信息请关注PHP中文网其他相关文章!