温馨提示×

如何在多个列上使用oracle的lag函数

小樊
81
2024-09-15 19:40:01
栏目: 云计算

在Oracle中,LAG()函数允许您在一个结果集的行中访问前一行的数据

SELECT 
    emp_id, 
    dept_id, 
    salary, 
    LAG(salary) OVER (PARTITION BY dept_id ORDER BY emp_id) as prev_dept_salary,
    LAG(salary) OVER (ORDER BY emp_id) as prev_global_salary
FROM employees;

这个查询将显示每个员工的ID、部门ID、工资以及他们所在部门和全局的前一个员工的工资。

在这个例子中,我们使用了两个LAG()函数,但是它们有不同的窗口:

  1. LAG(salary) OVER (PARTITION BY dept_id ORDER BY emp_id):此函数计算相同部门内前一个员工的工资。
  2. LAG(salary) OVER (ORDER BY emp_id):此函数计算按员工ID排序的全局前一个员工的工资。

您可以根据需要调整PARTITION BYORDER BY子句来适应您的需求。

0