SQL语句分页,不想用存储过程的朋友,可以直接用
本帖最后由 YokingChi 于 2022-7-20 15:56 编辑SELECT TOP 20 * FROM (select * from where State='1') AS tempTable
WHERE PKID > (SELECT ISNULL (MAX(PKID),0)
FROM (SELECT TOP 0【注:这个数字是 页大小 乘以 (第几页-1)】 PKID FROM
where State='1' ORDER BY PKID) A) ORDER BY PKID
备注:20 是页大小,就是每页显示多少条数据
PKID 是表的主键ID,自己替换关键字
DataTest_Table 是表名,自己替换
Where State=‘1’ 是查询条件,需要自己替换 2 处,没有查询条件(查询表所有数据)的,就不需要这两个Where条件。
AlvinWang76 发表于 2022-7-20 16:34
这个只能是SqlServer下使用吧,mysqloralce中 没有top这个语法吧
是的,这个是MSSQLServer语句,50000条数据,连续点击没有延迟感 414269678 发表于 2022-7-20 16:53
5w数据太少了,mssql有offset fetch 为啥不用,再不行row_number,没测试,目测top最慢的。
大佬方便提供下性能最优的,谢谢 这个只能是SqlServer下使用吧,mysqloralce中 没有top这个语法吧 每日签到打卡
mssql?运行会慢吗? MSSQL语句,测试数据用了50000条,每页20条数据,连续点击下一页,感觉不到延迟。 5w数据太少了,mssql有offset fetch 为啥不用,再不行row_number,没测试,目测top最慢的。 来个oracle的 4899 发表于 2022-7-20 17:24
来个oracle的
row_number 或者 12c之后的row limit
页:
[1]
2