MySql:
MySQL數(shù)據(jù)庫實(shí)現(xiàn)分頁比較簡(jiǎn)單,提供了 LIMIT函數(shù)。一般只需要直接寫到sql語句后面就行了。
LIMIT子 句可以用來限制由SELECT語句返回過來的數(shù)據(jù)數(shù)量,它有一個(gè)或兩個(gè)參數(shù),如果給出兩個(gè)參數(shù), 第一個(gè)參數(shù)指定返回的第一行在所有數(shù)據(jù)中的位置,從0開始(注意不是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)分頁,select * from 表名 limit 開始記錄數(shù),顯示多少條;就可以實(shí)現(xiàn)我們的分頁效果。
但是在oracle中沒有l(wèi)imit關(guān)鍵字,但是有 rownum字段
rownum是一個(gè)偽列,是oracle系統(tǒng)自動(dòng)為查詢返回結(jié)果的每行分配的編號(hào),第一行為1,第二行為2,以此類推。。。。
第一種:
其中最內(nèi)層的查詢SELECT * FROM TABLE_NAME表示不進(jìn)行翻頁的原始查詢語句。ROWNUM = 40和RN >= 21控制分頁查詢的每頁的范圍。
上面給出的這個(gè)分頁查詢語句,在大多數(shù)情況擁有較高的效率。分頁的目的就是控制輸出結(jié)果集大小,將結(jié)果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現(xiàn)在WHERE ROWNUM = 40這句上。
選擇第21到40條記錄存在兩種方法,一種是上面例子中展示的在查詢的第二層通過ROWNUM = 40來控制最大值,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的WHERE ROWNUM = 40語句,在查詢的最外層控制分頁的最小值和最大值。
第二種:
紅色部分:按照工資降序排序并查詢所有的信息。
棕色部分:得到紅色部門查詢的值,并查詢出系統(tǒng)的rownum并指定上別名。這一句就比較關(guān)鍵,起了一個(gè)過渡的作用,首先要算出rownum來對(duì)紅色部分指定上序號(hào),也可以為藍(lán)色外面部分用到這個(gè)變量。指定上查詢的開始記錄數(shù)和結(jié)束記錄的條件。
藍(lán)色部分:指定記錄從第幾條開始到第幾條結(jié)束,取出棕色部門的值來作為查詢條件的變量
總結(jié):絕大多數(shù)的情況下,第一個(gè)查詢的效率比第二個(gè)高得多。
SqlServer:
分頁方案一:(利用Not In和SELECT TOP分頁)
語句形式:
FROM TestTable
WHERE (ID NOT IN
(SELECT TOP 20 id
FROM TestTable
ORDER BY id))
ORDER BY ID
SELECT TOP 頁大小 *
FROM TestTable
WHERE (ID NOT IN
(SELECT TOP 頁大小*頁數(shù) id
FROM 表
ORDER BY id))
ORDER BY ID
分頁方案二:(利用ID大于多少和SELECT TOP分頁)
語句形式:
FROM TestTable
WHERE (ID >
(SELECT MAX(id)
FROM (SELECT TOP 20 id
FROM TestTable
ORDER BY id) AS T))
ORDER BY ID
SELECT TOP 頁大小 *
FROM TestTable
WHERE (ID >
(SELECT MAX(id)
FROM (SELECT TOP 頁大小*頁數(shù) id
FROM 表
ORDER BY id) AS T))
ORDER BY ID
分頁方案三:(利用SQL的游標(biāo)存儲(chǔ)過程分頁)
@sqlstr nvarchar(4000), --查詢字符串
@currentpage int, --第N頁
@pagesize int --每頁行數(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 總頁數(shù)--,@rowcount as 總行數(shù),@currentpage as 當(dāng)前頁
set @currentpage=(@currentpage-1)*@pagesize+1
exec sp_cursorfetch @P1,16,@currentpage,@pagesize
exec sp_cursorclose @P1
set nocount off
其它的方案:如果沒有主鍵,可以用臨時(shí)表,也可以用方案三做,但是效率會(huì)低。
建議優(yōu)化的時(shí)候,加上主鍵和索引,查詢效率會(huì)提高。
通過SQL 查詢分析器,顯示比較:結(jié)論是:
分頁方案二:(利用ID大于多少和SELECT TOP分頁)效率最高,需要拼接SQL語句
分頁方案一:(利用Not In和SELECT TOP分頁) 效率次之,需要拼接SQL語句
分頁方案三:(利用SQL的游標(biāo)存儲(chǔ)過程分頁) 效率最差,但是最為通用
在實(shí)際情況中,要具體分析。
標(biāo)簽:呼和浩特 江蘇 新鄉(xiāng) 拉薩 昭通 貴州 重慶 上海
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《oracle,mysql,SqlServer三種數(shù)據(jù)庫的分頁查詢的實(shí)例》,本文關(guān)鍵詞 oracle,mysql,SqlServer,三種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。