数据库分页查询

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

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

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

今天遇到了这个问题。

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

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页要显示的数据了。

是不是很简单。

相关推荐
就叫飞六吧8 分钟前
MySQL 驱动里那个 `cj` 到底是什么?
数据库·mysql
MageGojo12 分钟前
短链还原 API 怎么接入:展开跳转链路、查看状态码和最终落地页
数据库·redis·缓存
蚰蜒螟24 分钟前
从mkdir命令到磁盘:Linux内核目录创建过程深度解析
linux·运维·数据库
我是一颗柠檬24 分钟前
【Redis】字符串与哈希Day3(2026年)
数据库·redis·后端·database
sakoba25 分钟前
MySQL常见问题学习
数据库·学习·mysql
小二·26 分钟前
向量数据库深度对比:PGVector vs Qdrant vs Milvus vs Chroma(附性能测试数据)
数据库·wpf·milvus
sleven fung31 分钟前
Milvus 向量数据库
开发语言·数据库·python·langchain·milvus
赵渝强老师1 小时前
【赵渝强老师】崖山数据库的数据字典
数据库·oracle
kaico20181 小时前
FastAPI 框架 - 高级部分
oracle·fastapi
java_cj1 小时前
MySQL 8.0 新特性深度解析:降序索引、Doublewrite Buffer 与 redo log 无锁优化
数据库·mysql