zoukankan      html  css  js  c++  java
  • 【转载】Sqlserver的SQL语句实现分页查询

    在应用程序的开发中,如果数据库中的数据量过于的庞大,则需要针对查询数据做分页处理,取出对应分页中的数据,在Sqlserver分页的语句写法中,有两种比较常用,一种是数据表中含有自增量Id的情况,可以根据Id的大小顺序进行分页,另一种是数据库中不存在Int类型的Id的情况,此时就需要通过Row_Number函数来实现分页。

    (1)数据表中存在自增量Id的情况

    假设我们查询的表名称为Student,包含的字段有:Id(Id号,自增变量)、Name(姓名)、BirthDay(出生日期)。按出生日期从早到晚排序,获取排序后第31到60个学生的信息,语句可以使用Select Top的方式书写。具体如下:

    Select Top 30 * FROM Student Where Id Not In (Select Top 30 FROM Student Order By BirthDay) Order By BirthDay

    如果是获取第91到120排位的学生的话,则是下列语句。

    Select Top 30 * FROM Student Where Id Not In (Select Top 90 FROM Student Order By BirthDay) Order By BirthDay

    (2)数据表中不存在Id的情况

    此种情况不可能再使用top来排序了,可使用row_Number进行排序后再筛选对应的值。

    更改上述的Student表的结构为:StudentCode(文本类型,非数字)、Name(姓名)、BirthDay(出生日期)。按出生日期从早到晚排序,获取排序后第31到60个学生的信息,此时的SQL语句为:

    With tempTb AS
    (
       Select ROW_NUMBER() OVER(order by BirthDay ASC) AS RowNumber,* FROM Student
    )
    Select * FROM tempTb Where RowNumber>30 AND RowNumber<=60

    在临时表tempTb中使用了ROW_NUMBER() OVER来获取排序后的序号,Over里面为排序的规则。

    备注:此文章转载自博主个人技术站点,博主个人站致力于分享相关技术文章,同时也分享Windows服务器和Linux服务器运维等知识:IT技术小趣屋

    转载请标明出处。

      博主个人技术交流群:960640092,博主微信公众号如下:

  • 相关阅读:
    奖券数目
    用jQuery和ajax实现搜索框文字自动补全功能
    简单的文件上传功能实现(java)
    示例演示公告通知标题无缝向上滚动,文字段落无缝向上滚动,简单的wangeditor富文本编辑器,简单的音乐播放demo
    SSM框架中注解含义及应用场景小结
    数据库优化以及SQL优化小结
    javaWEB中前后台乱码解决问题小结
    线程同步的方法
    MySQL的简单使用
    springMVC运行流程图及运行原理
  • 原文地址:https://www.cnblogs.com/xu-yi/p/10446922.html
Copyright © 2011-2022 走看看