如何解决SQL滞后函数和where子句
我是SQL的新手,我想编写一个查询,将相同项目的行保留在其中:
- column1_value为NULL并且
- 先前的非null column1_value是'end'或
- 上一列1的值为NULL
其他一切都讨价还价。
我知道我必须使用LAG函数,但无法到达最终查询。你能帮忙吗?
预先感谢
解决方法
如果我理解正确:
select t.*
from (select t.*,lag(column1) over (order by ordercol) as prev_column1
from t
) t
where column1 is null and
(prev_column1 = 'end' or prev_column1 is null)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。