前言
昨天改小程序的后台,看见之前写的分页很奇怪,
startIndex
和endIndex
两个下标, endIndex 总是在里面层,而startIndex总是在外层,我随后改了,直接Where rownum > startIndex and rowmnum <=endIndex
, 结果只查出来了第一页,后面页查不出来了。
原因
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开始,因此,永远取不到数据。
最后
此致,敬礼