源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

mysql oracle和sqlserver分页查询实例解析

  • 时间:2020-06-10 06:28 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:mysql oracle和sqlserver分页查询实例解析
最近简单的对oracle,mysql,sqlserver2005的数据分页查询作了研究,把各自的查询的语句贴出来供大家学习..... [b](一)、mysql的分页查询[/b] mysql的分页查询是最简单的,借助关键字limit即可实现查询,查询语句通式:
selecto.*from(sql)o limit firstIndex,pageSize
如下面的截图,每页显示的记录数为20: 查询(1-20)这20条记录 [img]http://files.jb51.net/file_images/article/201710/2017101014405723.jpg[/img] 查询(21-40)这20条记录 [img]http://files.jb51.net/file_images/article/201710/2017101014405824.jpg[/img] mysql的分页查询就这么简单...... [b](二)、sqlserver2005的分页查询[/b] 在sqlserver2005之前一直借助top关键字来实现分页查询,不过效率低,在sqlserver2005及其之后的版本都使用row_number()解析函数来完成分页查询,效率有了很大的提高,不过sql语句比较复杂,下面给出分页查询的通式:
selecttoppageSizeo.*from(selectrow_number()over(orderbyorderColumn)asrownumber,*from(sql)asowhererownumber>firstIndex;
下面看截图,每页显示20条记录数: 查询(1-20)这20条记录 [img]http://files.jb51.net/file_images/article/201710/2017101014405825.jpg[/img] 查询(21-40)这20条记录 [img]http://files.jb51.net/file_images/article/201710/2017101014405826.jpg[/img] 知道了sqlserver中的row_number函数,分页也就简单了..... [b](三)、oracle分页查询[/b] 接下来重点说说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) [img]http://files.jb51.net/file_images/article/201710/2017101014405927.jpg[/img] 查询(22-41)这20条记录*****(没有ID=6的记录,所以开始查询到的ID为22,以及最大ID为41) [img]http://files.jb51.net/file_images/article/201710/20171010144722626.png?2017910144734[/img] ②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) [img]http://files.jb51.net/file_images/article/201710/2017101014410228.jpg[/img] 查询(22-41)这20条记录*****(没有ID=6的记录,所以开始查询到的ID为22,以及最大ID为41) [img]http://files.jb51.net/file_images/article/201710/2017101014410329.jpg[/img] 在ROWNUM查询的方式中,在第二层的sql语句中有个"[code]where ROWNUM<(firstIndex+pageSize)order by idasc[/code],从数据表中查询出(firstIndex+pageSize)条记录,所以如果这个值很小的话,效率会很好,如果对于大数据量的表单,这个值如果是上千,比如:[code]select* from wyuse where rownum<(5000) order by idasc[/code],这样一开始会选出5000条记录,效率自然会慢很多.... [b]总结[/b] 以上所述是小编给大家介绍的mysql oracle和sqlserver分页查询,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部