怎么在oracle中使用rownum实现分页?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
rownum是Oracle数据库中的一个特有关键字,返回的是一个数字代表记录的行号。
基础知识:rownum只能做<或者<=的条件查询,如果要rownum进行51到100这样的范围判断,需要先查询出每一行的rownum,再用那个序号做判断
获取51到100的数据
三种分页的写法:
1.使用minus,原理就是查询出前100行的数据 减去 查询出前50行的数据
select * from DATA_TABLE_sql where rownum<=100 minus select * from DATAT_ABLE_sql where rownum<=50
2.查询出所有数据的rownum,然后再选择50到100的数据(不推荐)
select * from (select t.*,rownum num from DATA_TABLE_sql t) where num<=100 and num>50
3.限定范围100条数据,并查询出这100条的rownum,然后再选择50到100的数据
select * from (select t.*,rownum num from DATA_TABLE_sql t where rownum<=100 ) where num>50
1:单表查询
SELECT * FROM (SELECT t.*,ROWNUM r FROM TABLE t WHERE ROWNUM <= pageNumber*pageSize) WHERE r >(pageNumber)*pageSize
2:两张表联查
SELECT * FROM (SELECT ROWNUM RN,XX.* FROM (SELECT 表名.字段名, 表名.字段名, 表名.字段名... FROM TABLE1 t1, TABLE2 t2 WHERE t1.字段=t2.字段) XX WHERE ROWNUM<=pageSize*pageNumber) WHERE RN >(pageNumber-1)*pageSize
看完上述内容,你们掌握怎么在oracle中使用rownum实现分页的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程之家行业资讯频道,感谢各位的阅读!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。