SQL分页查询的几种写法

在SqlServer中,分页查询是经常用到的查询语句,一个好的分页查询语句,不能能将代码省略,还能提高运行效率,下面总结一下SQLServer中的分页查询语句。

下面例子是每页50条,198*50=9900,取第199页数据。

--写法1:not in/top

select top 50 * from pagetest where id not in (select top 9900 id from pagetest order by id) order by id--写法2:not existsselect top 50 * from pagetest where not exists (select 1 from (select top 9900 id from pagetest order by id)a where a.id=pagetest.id) order by id

--写法3:max/top

select top 50 * from pagetest where id>(select max(id) from (select top 9900 id from pagetest order by id)a) order by id

--写法4:row_number()

select top 50 * from (select row_number()over(order by id)rownumber,* from pagetest)a where rownumber>9900   select * from (select row_number()over(order by id)rownumber,* from pagetest)a where rownumber>9900 and rownumber<9951 select * from ( select row_number()over(order by id)rownumber,* from pagetest)a where rownumber between 9901 and 9950

--写法5:row_number() 变体,不基于已有字段产生记录序号,先按条件筛选以及排好序,再在结果集上给一常量列用于产生记录序

select * from ( select row_number()over(order by tempColumn)rownumber,* from ( select top 9950 tempColumn=0,* from pagetest where 1=1 order by id)a )b where rownumber>9900

结论

1.max/top,ROW_NUMBER()都是比较不错的分页方法。相比ROW_NUMBER()只支持sql2005及以上版本,max/top有更好的可移植性,能同时适用于sql2000,access。

2.not exists感觉是要比not in效率高一点点。

3.ROW_NUMBER()的3种不同写法效率看起来差不多。

4.ROW_NUMBER() 的变体效率不是很好。

—— 完 ——
相关推荐
评论

立 为 非 似

中 谁 昨 此

宵 风 夜 星

。 露 , 辰

文章点击榜

细 无 轻 自

如 边 似 在

愁 丝 梦 飞

。 雨 , 花