吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1904|回复: 14
收起左侧

[其他原创] SQL语句分页,不想用存储过程的朋友,可以直接用

  [复制链接]
YokingChi 发表于 2022-7-20 15:53
本帖最后由 YokingChi 于 2022-7-20 15:56 编辑

[SQL] 纯文本查看 复制代码
SELECT TOP 20 * FROM (select * from [DataTest_Table] where State='1') AS tempTable 
WHERE PKID > (SELECT ISNULL (MAX(PKID),0)
 FROM (SELECT TOP 0【注:这个数字是 页大小 乘以 (第几页-1)】 PKID FROM [DataTest_Table] 
where State='1' ORDER BY PKID) A) ORDER BY PKID

备注:20 是页大小,就是每页显示多少条数据
           PKID 是表的主键ID,自己替换关键字
       DataTest_Table 是表名,自己替换
       Where State=‘1’ 是查询条件,需要自己替换 2 处,没有查询条件(查询表所有数据)的,就不需要这两个Where条件。

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| YokingChi 发表于 2022-7-20 16:44
AlvinWang76 发表于 2022-7-20 16:34
这个只能是SqlServer下使用吧,mysql  oralce中 没有top这个语法吧

是的,这个是MSSQLServer语句,50000条数据,连续点击没有延迟感
3650798 发表于 2022-7-20 16:58
414269678 发表于 2022-7-20 16:53
5w数据太少了,mssql有offset fetch 为啥不用,再不行row_number,没测试,目测top最慢的。

大佬方便提供下性能最优的,谢谢
AlvinWang76 发表于 2022-7-20 16:34
这个只能是SqlServer下使用吧,mysql  oralce中 没有top这个语法吧
jt0124 发表于 2022-7-20 16:35
每日签到打卡
3650798 发表于 2022-7-20 16:35
mssql?运行会慢吗?
 楼主| YokingChi 发表于 2022-7-20 16:44
MSSQL语句,测试数据用了50000条,每页20条数据,连续点击下一页,感觉不到延迟。
414269678 发表于 2022-7-20 16:53
5w数据太少了,mssql有offset fetch 为啥不用,再不行row_number,没测试,目测top最慢的。
4899 发表于 2022-7-20 17:24
来个oracle的
njbb888 发表于 2022-7-20 18:01

row_number 或者 12c之后的row limit
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-1 06:25

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表