注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

是缘是情是童真

如果你用笑脸面对 你会看见别人的笑脸

 
 
 

日志

 
 

各种分页SQL  

2011-08-10 11:45:35|  分类: 默认分类 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

使用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

  评论这张
 
阅读(152)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018