在Oracle中,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())或自定义聚合函数。