关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL语言 »SQL中的分页查询语句介绍(1)

    SQL中的分页查询语句介绍(1)

    2010-09-07 10:35:00 出处:ITJS
    分享

    使用SQL语句查询时,假如表里的记录数过于庞大,就需要用到分页查询语句,接下来的SQL server内容就将为您详细介绍SQL中的分页查询语句,供您参考。

    在实际中我们经常遇到表里的记录数非常庞大(数万至数百万),而一次只显示几十条数据的情况,假如我们直接用下面的SQL语句查询并填充到DataTable的话,将是一个非常恐怖的事情(假设UserInfo有几百万用户数据): Select * from UserInfo

    分页查询就是根据需要每次只返回所需要的数据,而不用每次都从数据库中全部把数据提取出来,这样可以降低程序与数据库之间的数据传送量,并且还可以提高程序的性能。 一般来说我们在数据量大的情况下总是会分页显示(谁也不会一下子将几万条数据全部一次性显示给用户),这样决定我们返回的查询结果集的参数有两个:当前显示的页数pageIndex和每页显示的记录条数size。这里来举例在SQL Server中我们如何写分页查询的SQL语句,假设我们按照UserID字段降序查询,每页显示5条记录。查询语句如下:

    view source

    print
    1 select top 5 * from UserInfo order by UserID asc

    第一页我们可以按照对UserID降序查询,并利用top 5取出前5条记录。可是第二页的SQL语句我们该怎么写呢?第二页显示的数据应该是按照UserID降序排列之后第6条到10条记录,有没有办法做到这一点呢?有两种办法:第一种就是前面我所提到的一次性将全部数据提取并填充到DataTable中,然后在for循环中通过i从5开始,并且i小于10(因为在C#中所有的集合下标都是从0开始的,第六条记录的下标就是5)这种方法显示5条数据,但是这种做法的缺点我在过去不久的文章里也提到了。第二种办法就是在数据库中过滤。我们通过分析发现,第二页要显示的记录的UserID字段有以下特点:它们是紧跟这第一页显示的记录之后的5条记录,也就是通过对UserID字段进行降序排列时,它们是除了第一页数据之后的5条记录,也就是它们的UserID不在第一页的UserID之中,在SQL语句有一个not in这个正好可以排上用场。 首先我们按照对UserID进行降序排序,查询出前面第一页使用的数据的UserID,SQL语句及执行结果如下:

    view source

    print
    1 select top 5 * from UserInfo where UserId not in
    2 (select top 5 UserID from UserInfo order by UserID asc)order by UserID asc

    UserID是从1开始,所以UserID在1至5的记录在第一页显示,UserID为6至10的记录在第二页显示,UserID为11至15的记录在第三页显示……依此类推,假如每页显示5条记录,那么第n页显示的数据记录的公式应该是:

    view source

    print
    1 select top 5 * from UserInfo where UserId not in 
    2 (select top (n-1)*5 UserID from UserInfo order by UserID asc) order by UserID asc

    需要注意的是:上面的查询,两次都是对UserID进行排序,并且都是降序,也就是说我们分页查询的时候写这种SQL语句的时候一定要都是对同一字段进行相同方式(asc或desc)的排序查询,这样查询的结果才会正确。 还有一点,如何查询数据库满足条件的记录条数呢? 还记得我讲过Command对象的ExecuteScalar()方法吧,这个方法就是返回查询结果的第一行第一列的。

    使用SQL语句查询时,假如表里的记录数过于庞大,就需要用到分页查询语句,接下来的SQL server内容就将为您详细介绍SQL中的分页查询语句,供您参考。

    在实际中我们经常遇到表里的记录数非常庞大(数万至数百万),而一次只显示几十条数据的情况,假如我们直接用下面的SQL语句查询并填充到DataTable的话,将是一个非常恐怖的事情(假设UserInfo有几百万用户数据): Select * from UserInfo

    分页查询就是根据需要每次只返回所需要的数据,而不用每次都从数据库中全部把数据提取出来,这样可以降低程序与数据库之间的数据传送量,并且还可以提高程序的性能。 一般来说我们在数据量大的情况下总是会分页显示(谁也不会一下子将几万条数据全部一次性显示给用户),这样决定我们返回的查询结果集的参数有两个:当前显示的页数pageIndex和每页显示的记录条数size。这里来举例在SQL Server中我们如何写分页查询的SQL语句,假设我们按照UserID字段降序查询,每页显示5条记录。查询语句如下:

    view source

    print
    1 select top 5 * from UserInfo order by UserID asc

    第一页我们可以按照对UserID降序查询,并利用top 5取出前5条记录。可是第二页的SQL语句我们该怎么写呢?第二页显示的数据应该是按照UserID降序排列之后第6条到10条记录,有没有办法做到这一点呢?有两种办法:第一种就是前面我所提到的一次性将全部数据提取并填充到DataTable中,然后在for循环中通过i从5开始,并且i小于10(因为在C#中所有的集合下标都是从0开始的,第六条记录的下标就是5)这种方法显示5条数据,但是这种做法的缺点我在过去不久的文章里也提到了。第二种办法就是在数据库中过滤。我们通过分析发现,第二页要显示的记录的UserID字段有以下特点:它们是紧跟这第一页显示的记录之后的5条记录,也就是通过对UserID字段进行降序排列时,它们是除了第一页数据之后的5条记录,也就是它们的UserID不在第一页的UserID之中,在SQL语句有一个not in这个正好可以排上用场。 首先我们按照对UserID进行降序排序,查询出前面第一页使用的数据的UserID,SQL语句及执行结果如下:

    view source

    print
    1 select top 5 * from UserInfo where UserId not in
    2 (select top 5 UserID from UserInfo order by UserID asc)order by UserID asc

    UserID是从1开始,所以UserID在1至5的记录在第一页显示,UserID为6至10的记录在第二页显示,UserID为11至15的记录在第三页显示……依此类推,假如每页显示5条记录,那么第n页显示的数据记录的公式应该是:

    view source

    print
    1 select top 5 * from UserInfo where UserId not in 
    2 (select top (n-1)*5 UserID from UserInfo order by UserID asc) order by UserID asc

    需要注意的是:上面的查询,两次都是对UserID进行排序,并且都是降序,也就是说我们分页查询的时候写这种SQL语句的时候一定要都是对同一字段进行相同方式(asc或desc)的排序查询,这样查询的结果才会正确。 还有一点,如何查询数据库满足条件的记录条数呢? 还记得我讲过Command对象的ExecuteScalar()方法吧,这个方法就是返回查询结果的第一行第一列的。

    下面是例子:

    view source

    print
    01 //实例化Connection对象 
    02 SqlConnection connection = new SqlConnection("server=localhost;database=pubs;uid=sa;pwd='' "); 
    03 //实例化Command对象 
    04 SqlCommand command = new SqlCommand("select count(1) as 男性人数 from UserInfo where sex=1", connection); 
    05 //打开Connection对象 
    06 connection.Open(); 
    07 //执行SQL语句 
    08 //得到第一行第一列的结果,这里是所有用户总数 
    09 int count = int.Parse(command.ExecuteScalar().ToString()); 
    10 //关闭Connection对象 
    11 connection.Close();

    最后一点,假如计算总页数的问题。假如我们有20条记录,每页显示5条,毫无疑问总共分4页显示。假如是21条记录呢?答案是分5页显示,尽管最后一页只有一条记录,但是还是要显示的。这里也有一个公式,假如总共有m条记录,每页显示n条记录(这里m,n都是大于0的整数)那么需要显示全部记录所用到的页数page为:

    view source

    print
    1 page=(m%n)==0 (m/n):(m/n+1);
    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    正版 Windows 11产品密钥怎么查找/查看?

    还有3个月,微软将停止 Windows 10 的更新

    Windows 10 终止支持后,企业为何要立即升级?

    Windows 10 将于 2025年10 月终止技术支持,建议迁移到 Windows 11

    Windows 12 发布推迟,微软正全力筹备Windows 11 25H2更新

    Linux 退出 mail的命令是什么

    Linux 提醒 No space left on device,但我的空间看起来还有不少空余呢

    hiberfil.sys文件可以删除吗?了解该文件并手把手教你删除C盘的hiberfil.sys文件

    Window 10和 Windows 11哪个好?答案是:看你自己的需求

    盗版软件成公司里的“隐形炸弹”?老板们的“法务噩梦” 有救了!

    IT头条

    公安部:我国在售汽车搭载的“智驾”系统都不具备“自动驾驶”功能

    02:03

    液冷服务器概念股走强,博汇、润泽等液冷概念股票大涨

    01:17

    亚太地区的 AI 驱动型医疗保健:2025 年及以后的下一步是什么?

    16:30

    智能手机市场风云:iPhone领跑销量榜,华为缺席引争议

    15:43

    大数据算法和“老师傅”经验叠加 智慧化收储粮食尽显“科技范”

    15:17

    技术热点

    SQL汉字转换为拼音的函数

    windows 7系统无法运行Photoshop CS3的解决方法

    巧用MySQL加密函数对Web网站敏感数据进行保护

    MySQL基础知识简介

    Windows7和WinXP下如何实现不输密码自动登录系统的设置方法介绍

    windows 7系统ip地址冲突怎么办?windows 7系统IP地址冲突问题的

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。