oracle,mysql,SqlServer三種數(shù)據(jù)庫(kù)的分頁(yè)查詢(xún)的實(shí)例
MySql:
MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)分頁(yè)比較簡(jiǎn)單,提供了 LIMIT函數(shù)。一般只需要直接寫(xiě)到sql語(yǔ)句后面就行了。
LIMIT子 句可以用來(lái)限制由SELECT語(yǔ)句返回過(guò)來(lái)的數(shù)據(jù)數(shù)量,它有一個(gè)或兩個(gè)參數(shù),如果給出兩個(gè)參數(shù), 第一個(gè)參數(shù)指定返回的第一行在所有數(shù)據(jù)中的位置,從0開(kāi)始(注意不是1),第二個(gè)參數(shù)指定最多返回行數(shù)。例如:
select * from table WHERE … LIMIT 10; #返回前10行
select * from table WHERE … LIMIT 0,10; #返回前10行
select * from table WHERE … LIMIT 10,20; #返回第10-20行數(shù)據(jù)
Oracle:
考慮mySql中的實(shí)現(xiàn)分頁(yè),select * from 表名 limit 開(kāi)始記錄數(shù),顯示多少條;就可以實(shí)現(xiàn)我們的分頁(yè)效果。
但是在oracle中沒(méi)有l(wèi)imit關(guān)鍵字,但是有 rownum字段
rownum是一個(gè)偽列,是oracle系統(tǒng)自動(dòng)為查詢(xún)返回結(jié)果的每行分配的編號(hào),第一行為1,第二行為2,以此類(lèi)推。。。。
第一種:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21
其中最內(nèi)層的查詢(xún)SELECT * FROM TABLE_NAME表示不進(jìn)行翻頁(yè)的原始查詢(xún)語(yǔ)句。ROWNUM <= 40和RN >= 21控制分頁(yè)查詢(xún)的每頁(yè)的范圍。
上面給出的這個(gè)分頁(yè)查詢(xún)語(yǔ)句,在大多數(shù)情況擁有較高的效率。分頁(yè)的目的就是控制輸出結(jié)果集大小,將結(jié)果盡快的返回。在上面的分頁(yè)查詢(xún)語(yǔ)句中,這種考慮主要體現(xiàn)在WHERE ROWNUM <= 40這句上。
選擇第21到40條記錄存在兩種方法,一種是上面例子中展示的在查詢(xún)的第二層通過(guò)ROWNUM <= 40來(lái)控制最大值,在查詢(xún)的最外層控制最小值。而另一種方式是去掉查詢(xún)第二層的WHERE ROWNUM <= 40語(yǔ)句,在查詢(xún)的最外層控制分頁(yè)的最小值和最大值。
第二種:
select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;
紅色部分:按照工資降序排序并查詢(xún)所有的信息。
棕色部分:得到紅色部門(mén)查詢(xún)的值,并查詢(xún)出系統(tǒng)的rownum并指定上別名。這一句就比較關(guān)鍵,起了一個(gè)過(guò)渡的作用,首先要算出rownum來(lái)對(duì)紅色部分指定上序號(hào),也可以為藍(lán)色外面部分用到這個(gè)變量。指定上查詢(xún)的開(kāi)始記錄數(shù)和結(jié)束記錄的條件。
藍(lán)色部分:指定記錄從第幾條開(kāi)始到第幾條結(jié)束,取出棕色部門(mén)的值來(lái)作為查詢(xún)條件的變量
總結(jié):絕大多數(shù)的情況下,第一個(gè)查詢(xún)的效率比第二個(gè)高得多。
SqlServer:
分頁(yè)方案一:(利用Not In和SELECT TOP分頁(yè))
語(yǔ)句形式:
SELECT TOP 10 *
FROM TestTable
WHERE (ID NOT IN
(SELECT TOP 20 id
FROM TestTable
ORDER BY id))
ORDER BY ID
SELECT TOP 頁(yè)大小 *
FROM TestTable
WHERE (ID NOT IN
(SELECT TOP 頁(yè)大小*頁(yè)數(shù) id
FROM 表
ORDER BY id))
ORDER BY ID
分頁(yè)方案二:(利用ID大于多少和SELECT TOP分頁(yè))
語(yǔ)句形式:
SELECT TOP 10 *
FROM TestTable
WHERE (ID >
(SELECT MAX(id)
FROM (SELECT TOP 20 id
FROM TestTable
ORDER BY id) AS T))
ORDER BY ID
SELECT TOP 頁(yè)大小 *
FROM TestTable
WHERE (ID >
(SELECT MAX(id)
FROM (SELECT TOP 頁(yè)大小*頁(yè)數(shù) id
FROM 表
ORDER BY id) AS T))
ORDER BY ID
分頁(yè)方案三:(利用SQL的游標(biāo)存儲(chǔ)過(guò)程分頁(yè))
create procedure XiaoZhengGe
@sqlstr nvarchar(4000), --查詢(xún)字符串
@currentpage int, --第N頁(yè)
@pagesize int --每頁(yè)行數(shù)
as
set nocount on
declare @P1 int, --P1是游標(biāo)的id
@rowcount int
exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output
select ceiling(1.0*@rowcount/@pagesize) as 總頁(yè)數(shù)--,@rowcount as 總行數(shù),@currentpage as 當(dāng)前頁(yè)
set @currentpage=(@currentpage-1)*@pagesize+1
exec sp_cursorfetch @P1,16,@currentpage,@pagesize
exec sp_cursorclose @P1
set nocount off
其它的方案:如果沒(méi)有主鍵,可以用臨時(shí)表,也可以用方案三做,但是效率會(huì)低。
建議優(yōu)化的時(shí)候,加上主鍵和索引,查詢(xún)效率會(huì)提高。
通過(guò)SQL 查詢(xún)分析器,顯示比較:結(jié)論是:
分頁(yè)方案二:(利用ID大于多少和SELECT TOP分頁(yè))效率最高,需要拼接SQL語(yǔ)句
分頁(yè)方案一:(利用Not In和SELECT TOP分頁(yè)) 效率次之,需要拼接SQL語(yǔ)句
分頁(yè)方案三:(利用SQL的游標(biāo)存儲(chǔ)過(guò)程分頁(yè)) 效率最差,但是最為通用
在實(shí)際情況中,要具體分析。
相關(guān)文章
SQL中的單條件判斷函數(shù)IF和多條件判斷CASE WHEN的用法
MySQL提供了IF、IFNULL、CASE等條件判斷函數(shù),本文就來(lái)介紹一下SQL中的單條件判斷函數(shù)IF和多條件判斷CASE WHEN的用法,感興趣的可以了解一下2023-10-10SQL語(yǔ)句查詢(xún)是否為空 =null及null
SQL語(yǔ)句查詢(xún)是否為空 =null及null實(shí)現(xiàn)代碼。2009-06-06一文詳解如何遠(yuǎn)程連接SQLServer數(shù)據(jù)庫(kù)
sql?server是一款數(shù)據(jù)庫(kù)管理工具,其中有非常多實(shí)用的功能可以幫助用戶(hù)完成數(shù)據(jù)庫(kù)的管理操作,也有一些用戶(hù)在操作這款軟件的時(shí)候會(huì)需要用到遠(yuǎn)程連接功能,這篇文章主要給大家介紹了關(guān)于如何遠(yuǎn)程連接SQLServer數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下2023-10-10sql實(shí)現(xiàn)split函數(shù)的腳本
這篇文章主要介紹了sql實(shí)現(xiàn)split函數(shù)的腳本,大家參考使用吧2013-11-11sqlserver 不重復(fù)的隨機(jī)數(shù)
MSSQL有一個(gè)函數(shù)CHAR()是將int(0-255) ASCII代碼轉(zhuǎn)換為字符。那我們可以使用下面MS SQL語(yǔ)句,可以隨機(jī)生成小寫(xiě)、大寫(xiě)字母,特殊字符和數(shù)字2012-01-01SQL?Server?數(shù)據(jù)庫(kù)基礎(chǔ)編程詳解
這篇文章主要為大家介紹了SQL?Server?數(shù)據(jù)庫(kù)基礎(chǔ)編程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-01-01一道關(guān)于數(shù)據(jù)庫(kù)(經(jīng)典父子級(jí) ID 關(guān)聯(lián))更新題
這篇文章主要介紹了一道關(guān)于數(shù)據(jù)庫(kù)(經(jīng)典父子級(jí) ID 關(guān)聯(lián))更新題,大家?guī)兔ο胂脒€有其它解決思路沒(méi)有?2015-06-06MSSQL存儲(chǔ)過(guò)程學(xué)習(xí)筆記一 關(guān)于存儲(chǔ)過(guò)程
在寫(xiě)筆記之前,首先需要整理好這些概念性的東西,否則的話(huà),就會(huì)在概念上產(chǎn)生陌生或者是混淆的感覺(jué)。2011-05-05