SQL Server 2005 分页SQL

使用SQL Server 2005的T-SQL在服务器端进行分页是用到的SQL语句。

1、

 
  
1 select *
2   from ssp_soi
3   where ssp_soi_id in (
4 select ssp_soi_id
5 from (
6 select ssp_soi_id,
7 ROW_NUMBER() OVER ( ORDER BY ssp_soi_id) as nid
8 from ssp_soi
9 ) as tid
10 where nid between 21 and 50
11 )

 

2、

 
  
1 SELECT *
2   FROM (
3 select * ,ROW_NUMBER() Over ( order by ssp_soi_id) as rowNum
4 from ssp_soi )
5   as myTable
6   where rowNum between 21 and 50

 

3、

 
  
1 WITH OrderedOrders AS
2 ( SELECT * ,
3 ROW_NUMBER() OVER ( order by ssp_soi_id) as RowNumber
4   FROM ssp_soi )
5   SELECT *
6   FROM OrderedOrders
7   WHERE RowNumber between 21 and 50

 

 而在ORACLE中的分页语句也类似

1、

 

 
  
1 SELECT * FROM
2 (
3 SELECT A. * , ROWNUM RN
4 FROM ( SELECT * FROM s_command) A
5 WHERE ROWNUM <= 10
6 )
7   WHERE RN >= 1
 

 

2、

 
  
1 SELECT * FROM
2 (
3 SELECT A. * , ROWNUM RN
4 FROM ( SELECT * FROM s_command) A
5 )
6   WHERE RN BETWEEN 1 AND 10
 

 

而按效率来考虑,上述的第一种方法的效率要比第二种高很多。

这是由于CBO优化模式下,Oracle可以将外层的查询条件推 到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE ROWNUM <= 40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。

而第二个查询语句,由于查询条件BETWEEN 21 AND 40是存在于查询的第三层,而Oracle无法将第三层的查询条件推到最内层(即使推到最内层也没有意义,因为最内层查询不知道RN代表什么)。因此,对 于第二个查询语句,Oracle最内层返回给中间层的是所有满足条件的数据,而中间层返回给最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率 要比第一个查询低得多。

 

同时,Oracle也支持ROW_NUMBER() OVER (partition by 字段 order by 字段  ),如下:

 

 
  
1 WITH TMS_e_user AS (
2   SELECT ROW_NUMBER() over ( ORDER BY euse_id) ROWNO, e_user. * FROM e_user WHERE 1 = 1 )
3   SELECT * FROM TMS_e_user WHERE ROWNO BETWEEN 1 AND 5


MySQL则比较简单

1、

 
  
1 SELECT * FROM bus_register LIMIT 1 , 5

转载于:https://www.cnblogs.com/Jason_zhu/archive/2010/04/09/1708279.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值