问题描述
我是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)