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
而第二个查询语句,由于查询条件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