`
Jason_zhu
  • 浏览: 20823 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

SQL Server 2005 分页SQL

阅读更多

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

1、

select *
from ssp_soi
where ssp_soi_id in (
	select ssp_soi_id
	from (
		select ssp_soi_id,
		ROW_NUMBER() OVER(ORDER BY ssp_soi_id) as nid
		from ssp_soi
	) as tid
	where nid between 21 and 50
)
 

2、

SELECT *
FROM (
    select *,ROW_NUMBER() Over(order by ssp_soi_id) as rowNum 
    from ssp_soi ) 
as myTable
where rowNum between 21 and 50

 

3、

WITH OrderedOrders AS
(SELECT *,
	ROW_NUMBER() OVER (order by ssp_soi_id)as RowNumber
FROM ssp_soi )
SELECT *
FROM OrderedOrders
WHERE RowNumber between 21 and 50
 

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

1、

SELECT * FROM
(
    SELECT A.*, ROWNUM RN
    FROM (SELECT * FROM s_command) A
    WHERE ROWNUM <= 10
)
WHERE RN >= 1

 

2、

SELECT * FROM
(
    SELECT A.*, ROWNUM RN
    FROM (SELECT * FROM s_command) A
)
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 字段 ),如下:

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

 

MySQL则比较简单

1、

SELECT * FROM bus_register LIMIT 1, 5
 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics