中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

oracle、mysql和SqlServer三種數據庫的分頁查詢實例

發布時間:2021-09-13 22:58:11 來源:億速云 閱讀:112 作者:chen 欄目:數據庫

這篇文章主要介紹“oracle、mysql和SqlServer三種數據庫的分頁查詢實例”,在日常操作中,相信很多人在oracle、mysql和SqlServer三種數據庫的分頁查詢實例問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”oracle、mysql和SqlServer三種數據庫的分頁查詢實例”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

MySql:

MySQL數據庫實現分頁比較簡單,提供了 LIMIT函數。一般只需要直接寫到sql語句后面就行了。LIMIT子 句可以用來限制由SELECT語句返回過來的數據數量,它有一個或兩個參數,如果給出兩個參數, 第一個參數指定返回的第一行在所有數據中的位置,從0開始(注意不是1),第二個參數指定最多返回行數。例如:select * from table WHERE … LIMIT 10; #返回前10行select * from table WHERE … LIMIT 0,10; #返回前10行select * from table WHERE … LIMIT 10,20; #返回第10-20行數據

Oracle:

考慮mySql中的實現分頁,select * from 表名 limit 開始記錄數,顯示多少條;就可以實現我們的分頁效果。

但是在oracle中沒有limit關鍵字,但是有 rownum字段

rownum是一個偽列,是oracle系統自動為查詢返回結果的每行分配的編號,第一行為1,第二行為2,以此類推。。。。

第一種:

復制代碼 代碼如下: SELECT * FROM ( SELECT A.*, ROWNUM RN  FROM (SELECT * FROM TABLE_NAME) A  WHERE ROWNUM <= 40)WHERE RN >= 21

其中最內層的查詢SELECT * FROM TABLE_NAME表示不進行翻頁的原始查詢語句。ROWNUM <= 40和RN >= 21控制分頁查詢的每頁的范圍。

上面給出的這個分頁查詢語句,在大多數情況擁有較高的效率。分頁的目的就是控制輸出結果集大小,將結果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現在WHERE ROWNUM <= 40這句上。

選擇第21到40條記錄存在兩種方法,一種是上面例子中展示的在查詢的第二層通過ROWNUM <= 40來控制最大值,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的WHERE ROWNUM <= 40語句,在查詢的最外層控制分頁的最小值和最大值。

第二種:

復制代碼 代碼如下:select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;

紅色部分:按照工資降序排序并查詢所有的信息。

棕色部分:得到紅色部門查詢的值,并查詢出系統的rownum并指定上別名。這一句就比較關鍵,起了一個過渡的作用,首先要算出rownum來對紅色部分指定上序號,也可以為藍色外面部分用到這個變量。指定上查詢的開始記錄數和結束記錄的條件。

藍色部分:指定記錄從第幾條開始到第幾條結束,取出棕色部門的值來作為查詢條件的變量

總結:絕大多數的情況下,第一個查詢的效率比第二個高得多。

SqlServer:

分頁方案一:(利用Not In和SELECT TOP分頁)

語句形式:

復制代碼 代碼如下: SELECT TOP 10 *

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 頁大小*頁數 id

FROM 表

ORDER BY id))

ORDER BY ID

分頁方案二:(利用ID大于多少和SELECT TOP分頁)

語句形式:

復制代碼 代碼如下: 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 頁大小 *

FROM TestTable

WHERE (ID >

(SELECT MAX(id)

FROM (SELECT TOP 頁大小*頁數 id

FROM 表

ORDER BY id) AS T))

ORDER BY ID

分頁方案三:(利用SQL的游標存儲過程分頁)

復制代碼 代碼如下: create procedure XiaoZhengGe

@sqlstr nvarchar(4000), --查詢字符串

@currentpage int, --第N頁

@pagesize int --每頁行數

as

set nocount on

declare @P1 int, --P1是游標的id

@rowcount int

exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output

select ceiling(1.0*@rowcount/@pagesize) as 總頁數--,@rowcount as 總行數,@currentpage as 當前頁

set @currentpage=(@currentpage-1)*@pagesize+1

exec sp_cursorfetch @P1,16,@currentpage,@pagesize

exec sp_cursorclose @P1

set nocount off

其它的方案:如果沒有主鍵,可以用臨時表,也可以用方案三做,但是效率會低。

建議優化的時候,加上主鍵和索引,查詢效率會提高。

通過SQL 查詢分析器,顯示比較:結論是:

分頁方案二:(利用ID大于多少和SELECT TOP分頁)效率最高,需要拼接SQL語句

分頁方案一:(利用Not In和SELECT TOP分頁) 效率次之,需要拼接SQL語句

分頁方案三:(利用SQL的游標存儲過程分頁) 效率最差,但是最為通用

在實際情況中,要具體分析。

到此,關于“oracle、mysql和SqlServer三種數據庫的分頁查詢實例”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

礼泉县| 曲周县| 凤山市| 吴川市| 沅江市| 肃北| 涪陵区| 河池市| 通榆县| 大同市| 平阴县| 微博| 德化县| 西青区| 常德市| 仪陇县| 安新县| 东宁县| 九龙县| 德令哈市| 赤峰市| 建湖县| 营山县| 武鸣县| 靖边县| 宜昌市| 定州市| 太白县| 金山区| 安多县| 隆安县| 杭锦旗| 师宗县| 乌什县| 老河口市| 五华县| 望江县| 洛扎县| 光山县| 高尔夫| 阿拉善左旗|