mysql oracle和sqlserver分页查询实例解析
最近简单的对oracle,mysql,sqlserver2005的数据分页查询作了研究,把各自的查询的语句贴出来供大家学习.....
(一)、mysql的分页查询
mysql的分页查询是最简单的,借助关键字limit即可实现查询,查询语句通式:
selecto.*from(sql)o limit firstindex,pagesize
如下面的截图,每页显示的记录数为20:
查询(1-20)这20条记录
查询(21-40)这20条记录
mysql的分页查询就这么简单......
(二)、sqlserver2005的分页查询
在sqlserver2005之前一直借助top关键字来实现分页查询,不过效率低,在sqlserver2005及其之后的版本都使用row_number()解析函数来完成分页查询,效率有了很大的提高,不过sql语句比较复杂,下面给出分页查询的通式:
selecttoppagesizeo.*from(selectrow_number()over(orderbyordercolumn)asrownumber,*from(sql)asowhererownumber>firstindex;
下面看截图,每页显示20条记录数:
查询(1-20)这20条记录
查询(21-40)这20条记录
知道了sqlserver中的row_number函数,分页也就简单了.....
(三)、oracle分页查询
接下来重点说说oracle的分页查询,oracle的分页查询方法相对来说要多点,rownum、row_number(),今天主要将两种效率稍好的分页查询语句。
①rownum查询分页通式:
select*from(selecta.*,rownumrn from(sql)a whererownum<=(firstindex+pagesize))wherern>firstindex
以下截图是以这种方式进行的查询语句:
查询(1-21)这20条记录*****(没有id=6的记录,所以查询到的最大id为21)
查询(22-41)这20条记录*****(没有id=6的记录,所以开始查询到的id为22,以及最大id为41)
②row_number()解析函数分页查询方式:
select*from(select*from(selectt.*,row_number()over(orderbyordercolumn)asrownumberfrom(sql)t) p wherep.rownumber>firstindex)whererownum<=pagesize
以下截图是使用row_number()方式的分页查询效果:
查询(1-21)这20条记录*****(没有id=6的记录,所以查询到的最大id为21)
查询(22-41)这20条记录*****(没有id=6的记录,所以开始查询到的id为22,以及最大id为41)
在rownum查询的方式中,在第二层的sql语句中有个"where rownum<(firstindex+pagesize)order by idasc
,从数据表中查询出(firstindex+pagesize)条记录,所以如果这个值很小的话,效率会很好,如果对于大数据量的表单,这个值如果是上千,比如:select* from wyuse where rownum<(5000) order by idasc
,这样一开始会选出5000条记录,效率自然会慢很多....
总结
以上所述是小编给大家介绍的mysql oracle和sqlserver分页查询,希望对大家有所帮助
上一篇: scratch怎么制作圣诞老人的动画?
推荐阅读
-
oracle,mysql,SqlServer三种数据库的分页查询的实例
-
【SQL】Oracle和Mysql的分页、重复数据查询(limit、rownum、rowid)
-
oracle,mysql,SqlServer三种数据库的分页查询的实例
-
详解SQLServer和Oracle的分页查询
-
Oracle与MySQL的分页查询sql语句格式实例讲解
-
mysql oracle和sqlserver分页查询实例解析
-
SQLSERVER分页查询关于使用Top方式和row_number()解析函数的不同
-
MYSQL子查询和嵌套查询优化实例解析
-
MySQL、Oracle和SQL Server的分页查询
-
oracle和mysql实现分页查询