文章详情页
java - 遇到Oracle数据库分页查询的问题
浏览:195日期:2023-12-06 09:50:14
问题描述
是这样的,我这个表中有KS_ZKZ这个字段,这个字段在表中并不是唯一的,每个学号都出现了多次,我现在想依据这个学号来进行分页查询:首先把学号去重,并升序排列:
SELECT DISTINCT(KS_ZKZ) from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC

有了这个查询结果后,想查询这个结果的从rownum 为a到b的数据:
SELECT KS_ZKZ,ROWNUM FROM(SELECT DISTINCT(KS_ZKZ) from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC)WHERE ROWNUM >=10 AND ROWNUM<=20
但是问题出现了:下面是查询结果。。

为什么查不到呢?
问题解答
回答1:rownum只是一个伪列, 你里面那层需要查个rownum出来就行, 比如
SELECT KS_ZKZ FROM(SELECT DISTINCT(KS_ZKZ), ROWNUM rn from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC)WHERE rn between 10 AND 20 回答2:
rownum的判断必须以1开始,比如=1,<5都是成立的,但是=2,>7都必须先将结果集查出来,通过子语句再查询(rownum需要别名)
标签:
java
相关文章:
1. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””2. docker容器呢SSH为什么连不通呢?3. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!4. javascript - JAVA后台怎么设置表头的宽度5. docker-compose中volumes的问题6. java - 解决 类似“%22%3A%22”这样的字符串怎么解码?7. java - Ubuntu 使用IDEA搭建Tomcat?8. css - ul ol前边的标记如何调整样式呢9. javascript - 怎么设计项目的返回码,让不同的返回码代表不同的含义?10. redis - 究竟是选择微信小程序自带的统计工具还是自己开发一个数据统计的代码?
排行榜

网公网安备