java oracle分页查询语句_oracle 分页语句

java oracle分页查询语句_oracle 分页语句通过Debug调试,发现第一页查询到的数据没有问题,第二页时,查不到数据!第一页时,控制台打印的sql语句:SELECTOBJ_NAME,OBJ_ATTRIBUTE_NAME,ATTRIBUTE_TYPE,DES,STS,PRIORITYFROM(SELECTm.*,rownumrow_idFROM(SELECTOBJ_NAME,OBJ_ATTRIBUTE_NAME,ATT…

大家好,又见面了,我是你们的朋友全栈君。

通过Debug调试,发现第一页查询到的数据没有问题,第二页时,查不到数据!

第一页时,控制台打印的sql语句:

48304ba5e6f9fe08f3fa1abda7d326ab.png

SELECTOBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY

FROM( SELECT m.*,rownum row_id

FROM (SELECT OBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY FROMWKF_BUSINESS_CONFIG ) m

WHERE rownum >= 1)

where row_id < 26

48304ba5e6f9fe08f3fa1abda7d326ab.png

第二页时,控制台打印的sql语句:

48304ba5e6f9fe08f3fa1abda7d326ab.png

SELECTOBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY

FROM( SELECT m.*,rownum row_id

FROM (SELECT OBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY FROMWKF_BUSINESS_CONFIG ) m

WHERE rownum >= 26)

where row_id < 51

48304ba5e6f9fe08f3fa1abda7d326ab.png

通过分析和查询oracle分页的知识,发现是SQL语句有问题!

不能对ROWNUM使用>(大于1的数值)、>=(大于或等于1的数值)、=(大于或等于1的数值),否则无结果

— 所以直接用只能从1开始

— rownum >10 没有记录,因为第一条不满足去掉的话,第二条的rownum又成了1,所以永远没有满足条件的记录。

正好,查询第二页的时候,上面的sql语句犯了这个问题!

既然不能>=(大于或等于1的数值),那我就让rownum

48304ba5e6f9fe08f3fa1abda7d326ab.png

SELECTOBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY

FROM( SELECT m.*,rownum row_id

FROM(SELECTOBJ_NAME, OBJ_ATTRIBUTE_NAME, ATTRIBUTE_TYPE, DES, STS, PRIORITY

FROMWKF_BUSINESS_CONFIG ) m

WHERE rownum <51)

where row_id >= 26

48304ba5e6f9fe08f3fa1abda7d326ab.png

将sql语句改成这样时,按照要求可以查询到数据!

既然遇到了Oracle分页查询的问题,正好复习下Oracle分页的相关知识!

在Mysql中,分页查询很简单!    分页查询使用的是limit关键字进行查询。它后面有两个参数

第一个参数是起始的位置,第二个参数是每页需要显示的条目数。

举例:商品表中有10条记录,现在需要进行分页显示,每页显示3条数据。现在需要查看第二页的数据。那么应该使用的sql语句是:

select * from product limit 3,3;                   第一个参数计算的公式为:(查询的页数-1)*每页显示条目数    即 (2-1)*3=3

在Oracle中分页就没有那么简单!Oracle中是通过rownum实现分页查询的!

不能对ROWNUM使用>(大于1的数值)、>=(大于或等于1的数值)、=(大于或等于1的数值),否则无结果

所以直接用只能从1开始

rownum >10 没有记录,因为第一条不满足去掉的话,第二条的rownum又成了1,所以永远没有满足条件的记录。

select * from student where rownum>=1;

如果想要用rownum不从1开始,需按下面方法使用

select a1.* from (select student.*,rownum rn from student) a1 where rn >5

分页查询一

select * from (select a1.*,rownum rn from (select * from student) a1 where rownum <=5) where rn>=2;

分页查询二

select a1.* from (select student.*,rownum rn from student where rownum <=5) a1 where rn >=3;

分页查询三

select a1.* from (select student.*,rownum rn from student) a1 where rn between 3 and 5;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/140167.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm语法提示_pycharm怎么看函数参数

    pycharm语法提示_pycharm怎么看函数参数参考博客:https://www.cnblogs.com/wendj/archive/2018/09/21/9685012.html第三步:鼠标放到函数名,按住ctrl即可查看

  • linux下的录屏软件_Linux离线安装录屏

    linux下的录屏软件_Linux离线安装录屏在ubuntu和kalilinux下我测试了几款录屏软件,比较好用的是RecordMyDesktop。mac下录屏软件朋友介绍使用screenflow.按键显示工具keycastr。不过目前没有测试过。

  • 匿名函数自调用_自己调用自己的函数叫

    匿名函数自调用_自己调用自己的函数叫我们知道一个HTML文件在被加载的时候是从根标签html依次往下的,在遇到link,script等标签引入的外部资源时,下载外部资源,并执行外部资源。在js中,表达式会被立即执行,也就是说,不管是引入的外部js文件还是嵌入在html文件中的js脚本,其中的表达式都会被立即执行。函数名是一个指向函数的指针。在JavaScript中,定义函数有常见的两种形式:函数声明和函数直接量(或者叫函数表达式)

  • 关于php一句话木马

    关于php一句话木马服务器上发现被植了很多木马,而且还让人肆意使用…NND使用方法也很简单,本地提交文件指向提交文件,里面的php代码就会被执行

  • 子网掩码和ip地址的关系_ip地址和子网掩码求网络地址

    子网掩码和ip地址的关系_ip地址和子网掩码求网络地址1、什么是ip地址在网络中,所有的设备都会被分配一个地址。这个地址就相当于某条路上的XX号XX房。其中【号】对应的号码是分配了整个子网的,而【房】对应的号码是分配给子网中的计算机的,这就是网络中的地

  • 根据/proc/partitions获取插入的U盘设备名称

    根据/proc/partitions获取插入的U盘设备名称1 在/proc/partitions中存放着U盘的设备名称,如sda,sdb2等,以sd开头。major主设备号,比如一个U盘有3个分区,主设备名为sda,major为8,分区的major也为8,minor则为分区号,sda1,sda2,minor值为1,2sda的minor为0,name即为设备名,连接/dev./设备名,就可以挂载到一个目录。blocks表示物理设备逻辑块

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号