欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle,mysql,SqlServer三種數(shù)據(jù)庫(kù)的分頁(yè)查詢(xún)的實(shí)例

 更新時(shí)間:2013年03月13日 10:46:13   作者:  
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)推。。。。

第一種:

復(fù)制代碼 代碼如下:

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è)的最小值和最大值。

第二種:

復(fù)制代碼 代碼如下:

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ǔ)句形式:

復(fù)制代碼 代碼如下:

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ǔ)句形式:

復(fù)制代碼 代碼如下:

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è))

復(fù)制代碼 代碼如下:

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)文章

最新評(píng)論