在Oracle中,LAG函数用于获取分区或排序后的前一行数据
- 使用ROW_NUMBER()函数为每行分配唯一的行号。
- 使用LAG函数获取前一行的数据。
- 比较当前行和前一行的数据,以确定是否存在重复。
以下是一个示例:
WITH data AS ( SELECT empno, deptno, sal, ROW_NUMBER() OVER (PARTITION BY deptno ORDER BY empno) as row_num FROM emp ), lag_data AS ( SELECT empno, deptno, sal, row_num, LAG(empno) OVER (PARTITION BY deptno ORDER BY row_num) as prev_empno, LAG(sal) OVER (PARTITION BY deptno ORDER BY row_num) as prev_sal FROM data ) SELECT empno, deptno, sal, CASE WHEN empno = prev_empno AND sal = prev_sal THEN '重复' ELSE '非重复' END as duplicate_status FROM lag_data;
在这个示例中,我们首先使用ROW_NUMBER()函数为每个部门的员工分配一个唯一的行号。然后,我们使用LAG函数获取前一行的员工编号和薪水。最后,我们比较当前行和前一行的员工编号和薪水,以确定是否存在重复。
请注意,这个示例仅适用于具有相同部门和薪水的连续重复行。如果需要处理非连续重复行,可以考虑使用其他方法,例如使用窗口函数(如DENSE_RANK())或自定义聚合函数。