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

avatar
作者
筋斗云
阅读量:0

在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子句来适应您的需求。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!