数据库分页查询

数据库只所以要分页查询,其实是界面显示的需要,不是数据库的需要。

数据库本身查询是很快的。本文章是针对这种情况的。

如果数据库本身查询慢,那是优化查询语句的事情了。不在本文章范围内。

今天遇到了这个问题。

是个老项目。在原有的查询的基础上分页查询,提高显示效率。

1、尽量不作大的修改。
2、假设界面每页显示 1000 条数据。
3、下面 %sql% 可以是简单的表名,也可以是复杂的查询语句;
4、datetime 数据库排序字段。一般是最新的记录,显示在最前面;这里用时间字段;(降序)

第一页:

sql 复制代码
 select top 1000 * from (%sql%) order by datetime desc

**最末页:**用记录总数 mod 1000,计算出最末页要显示的记录个数。如果余数为0,那就是1000 条。否则就是余数 N。

sql 复制代码
 select * from 
  ( 
    select top N * from (%sql%) A order by datetime
  ) B order by datetime desc

原理:先升序查询数据,然后取出最前面的 N 条记录,就是最后一页要显示的 N 条记录了。再按降序排序。

**中间页:**有了上面最末页的思路,中间页也很容易实现了。

sql 复制代码
select * from 
  (
    select top 1000 * from 
    (
        select top 1000 * intPageIndex from (%sql%) A order by datetime desc
     ) B order by datetime
  ) C order by datetime desc

intPageIndex 为第几页。

原理和最末页的查询是一样的。

比如显示第5页,先按降序取出前 5000 条数据,再从这 5000 条数据中,取出最后的 1000 条,就是第5页要显示的数据了。

是不是很简单。

相关推荐
小冷coding9 分钟前
【MySQL】MySQL 插入一条数据的完整流程(InnoDB 引擎)
数据库·mysql
鲨莎分不晴1 小时前
Redis 基本指令与命令详解
数据库·redis·缓存
专注echarts研发20年1 小时前
工业级 Qt 业务窗体标杆实现・ResearchForm 类深度解析
数据库·qt·系统架构
周杰伦的稻香3 小时前
MySQL中常见的慢查询与优化
android·数据库·mysql
冉冰学姐3 小时前
SSM学生社团管理系统jcjyw(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·学生社团管理系统·多角色管理
nvd114 小时前
深入分析:Pytest异步测试中的数据库会话事件循环问题
数据库·pytest
appearappear4 小时前
如何安全批量更新数据库某个字段
数据库
·云扬·5 小时前
MySQL 常见存储引擎详解及面试高频考点
数据库·mysql·面试
羊小猪~~5 小时前
【QT】--文件操作
前端·数据库·c++·后端·qt·qt6.3
coding-fun6 小时前
电子发票批量提取导出合并助手
大数据·数据库