`

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

阅读更多


 表的结构如下:

 



如要查询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 ;

  • 大小: 17.1 KB
2
2
分享到:
评论
2 楼 luoyonghui55 2014-08-12  
你这个要是能再写一些注释说明就更好了。
1 楼 yybb2277 2011-11-29  
太强了,谢谢

相关推荐

    Oracle数据库速查知识文档,oracle使用手册

    Oracle的高级查询涉及到联接(JOIN)、子查询、集合操作(UNION、INTERSECT、EXCEPT)以及窗口函数(如`RANK`、`ROW_NUMBER`、`LEAD`、`LAG`)。这些技术允许对大数据集进行复杂分析,提取有价值的信息。 PL/SQL...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

     Oracle 数据库中的SQL是当今市场上功能最强大的SQL实现之一,而本书全面展示了这一工具的威力。如何才能让更多人有效地学习和掌握SQL呢?Karen Morton及其团队在本书中提供了专业的方案:先掌握语言特性,再学习...

    计算机sql语言的基础用法和常见用法

    这条命令将一条包含`id`、`name`和`email`字段的新记录添加到了`users`表格中。 ##### 2.3 查询数据(`SELECT`) 使用`SELECT`语句可以从数据库中检索数据。例如,检索`users`表格中的所有数据: ```sql SELECT *...

    SQL必知必会样例格数据以及SQL脚本.zip

    - ALTER TABLE:修改已有表的结构,如添加、删除或修改列。 - DROP:删除数据库或表。 3. **SQL查询进阶**: - JOIN:将两个或更多表的数据合并,有内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)...

    SQL语句基础PPT

    6. **窗口函数**: 窗口函数在每个行上执行计算,同时考虑当前行及其前后行,如RANK()、ROW_NUMBER()、LEAD()、LAG()等。 7. **分区表**: 分区是将大表分成较小、更易管理的部分,提高查询速度和维护效率。 8. **...

Global site tag (gtag.js) - Google Analytics