欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

oracle分页的使用,oracle中分页的实现方式.rownum的使用

发布时间:2023/11/27 51 豆豆
生活随笔 收集整理的这篇文章主要介绍了 oracle分页的使用,oracle中分页的实现方式.rownum的使用 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,而且rownum不能以任何表的名称作为前缀。

举例说明:

例如表:student(学生)表,表结构为:

ID       char(6)      --学号

name    VARCHAR2(10)   --姓名

create table student (ID char(6), name VARCHAR2(100));

insert into sale values('200001',‘张一’);

insert into sale values('200002',‘王二’);

insert into sale values('200003',‘李三’);

insert into sale values('200004',‘赵四’);

commit;

(1) rownum 对于等于某值的查询条件

如果希望找到学生表中第一条学生的信息,可以使用rownum=1作为条件。但是想找到学生表中第二条学生的信息,使用rownum=2结果查不到数据。因为rownum都是从1开始,但是1以上的自然数在rownum做等于判断是时认为都是false条件,所以无法查到rownum = n(n>1的自然数)。

SQL> select rownum,id,name from student where rownum=1;(可以用在限制返回记录条数的地方,保证不出错,如:隐式游标)

SQL> select rownum,id,name from student where rownum=1;

ROWNUM ID     NAME

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

1 200001 张一

SQL> select rownum,id,name from student where rownum =2;

ROWNUM ID     NAME

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

(2)rownum对于大于某值的查询条件

如果想找到从第二行记录以后的记录,当使用rownum>2是查不出记录的,原因是由于rownum是一个总是从1开始的伪列,Oracle 认为rownum> n(n>1的自然数)这种条件依旧不成立,所以查不到记录

SQL> select rownum,id,name from student where rownum >2;

ROWNUM ID     NAME

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

那如何才能找到第二行以后的记录呀。可以使用以下的子查询方法来解决。注意子查询中的rownum必须要有别名,否则还是不会查出记录来,

总结

以上是生活随笔为你收集整理的oracle分页的使用,oracle中分页的实现方式.rownum的使用的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。