oracle,mysql,sqlserver分頁查詢實現

1.oracle

使用關鍵字rownum嵌套查詢實現:

select * from (

? ? select a.*, rownum rn from(

? ? ? ? select * from 表名 order by 排序字段) a

? ? where rownum <= 30)

where rn >= 21;

2.mysql

使用limit函數:

1)取前5條數據

select * from 表名 limit 0,5;

或者

select * from 表名 limit 5;

2)查詢第11到第15條數據

select * from 表名 limit 10,5;

3)limit關鍵字的用法:

LIMIT[offset,]rows

offset指定要返回的第一行的偏移量,rows第二個指定返回行的最大數目。初始行的偏移量是0(不是1)。

3.sqlserver

使用top關鍵字:

--第一種

select top 10 ID from T where ID not in(select top 30 ID from T ORDER BY ID ASC)ORDER BY ID

--第二種

SELECT * FROM (select top 10 * FROM( select top 40 * from T order by ID asc)TT order by TT.ID DESC)TTT order by TTT.ID asc

--第三種

select * from T where T.ID in( select top 10 ID FROM(select top 40 ID from T order by T.ID asc)TT order by TT.ID desc) order by ID

--第四種

select * from( select ROW_NUMBER() over(order by ID)TT FROM T)TTT WHERE TTT.TT between 30 and 40

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容