zoukankan      html  css  js  c++  java
  • oracle中根据当前记录查询前一条和后一条记录

    select * from aa01_2014 where aaa001=(select c.p from (select aaa001,lag(aaa001,1,0)  over (order by aaa001) as p from aa01_2014) c where c.aaa001='8a9299ec522f54f401522f81eedc0007')  ;


    select * from aa01_2014 where aaa001=(select c.n from (select aaa001,lead(aaa001,1,0)  over (order by aaa001) as n from aa01_2014) c where c.aaa001='8a9299ec522f54f401522f81eedc0007') ;
     
     
     

    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

  • 相关阅读:

    每日小练习
    完数
    6.13的练习
    字典
    sql server多条记录同时插入一张表
    sql server从表到表——复制,备份
    Bootstrap关于row
    Bootstrap 关于标签,徽章,巨幕,页头,缩略图,自定义内容的使用
    Bootstrap 关于分页的使用
  • 原文地址:https://www.cnblogs.com/wjwen/p/5135187.html
Copyright © 2011-2022 走看看