码迷,mamicode.com
首页 > 数据库 > 详细

关于SQL中的ROWNUM问题

时间:2019-07-10 18:11:35      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:问题   数据   tar   记录   uri   HERE   查看   下标   昨天   

前言

昨天改小程序的后台,看见之前写的分页很奇怪,startIndexendIndex两个下标, endIndex 总是在里面层,而startIndex总是在外层,我随后改了,直接Where rownum > startIndex and rowmnum <=endIndex, 结果只查出来了第一页,后面页查不出来了。

客官可移步小站查看本文http://fanjiajia.cn/2019/07/10/SQL/flx1/

原因

Where rownum > 0 and rowmnum <=20,是可以查出前20条记录的,但是Where rownum >1 and rowmnum <=20,就不行了,所以只要是rownum>1都不可以。

上网查一番,原来ROWNUM作为一列虚列,也叫做伪列,总是从1开始,我知道这样说肯定觉得是废话。
举个例子,where rownum > 1, 结果是查不出数据,原因很简单,rownum总是从1开始,可以这样理解,查询过程即为从数据库的某一个数据区取值,第一行的rownum为1,第二行为2,但是限制条件where rownum > 1导致第一行数据不符合条件,被丢弃,此时取第二行数据,然而此时,rownum仍然从1开始,因为之前哪一行丢弃了,rownum依旧从1开始,因此,永远取不到数据。

最后

此致,敬礼

关于SQL中的ROWNUM问题

标签:问题   数据   tar   记录   uri   HERE   查看   下标   昨天   

原文地址:https://www.cnblogs.com/numen-fan/p/11165370.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!