oracle 利用 lead 、lag 查询已有记录的下一条、上一条记录

来源:互联网 发布:暖气安装注意事项知乎 编辑:程序博客网 时间:2024/05/02 03:04

 表的结构如下:

 



如要查询Staffno是6-1102的前一条记录

 

select * from staff where staff_no=(select c.p from (select staff_no,lag(staff_no,1,0)  over (order by staff_no) as p from staff) c where c.staff_no='6-1102')

结果:

STAFF_NO   STAFF_NAME           SEX 

---------- -------------------- --- -

6-1076     梁柄聪               男                                                                                                                                                                                                                                                                           


1 rows selected

 

如要查询其后一条记录

 

select * from staff where staff_no=(select c.n from (select staff_no,lead(staff_no,1,0)  over (order by staff_no) as n from staff) c where c.staff_no='6-1102')

 

结果:

 

STAFF_NO   STAFF_NAME           SEX 

---------- -------------------- --- -

6-1103     余志伟               男                                                                                                                    


1 rows selected




 查询第一条

 select * from (select s.*,row_number()over(order by staff_no ) rn from staff s) where rn=1 ;

 查询最后一条

 select * from (select s.*,row_number()over(order by staff_no desc ) rn from staff s) where rn=1 ;

原创粉丝点击