久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實例

198次閱讀
沒有評論

共計 2626 個字符,預(yù)計需要花費 7 分鐘才能閱讀完成。

行業(yè)資訊    
數(shù)據(jù)庫    
oracle、mysql 和 SqlServer 三種數(shù)據(jù)庫的分頁查詢實例

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

MySql:

MySQL 數(shù)據(jù)庫實現(xiàn)分頁比較簡單,提供了 LIMIT 函數(shù)。一般只需要直接寫到 sql 語句后面就行了。LIMIT 子 句可以用來限制由 SELECT 語句返回過來的數(shù)據(jù)數(shù)量,它有一個或兩個參數(shù),如果給出兩個參數(shù),第一個參數(shù)指定返回的第一行在所有數(shù)據(jù)中的位置,從 0 開始(注意不是 1),第二個參數(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 中的實現(xiàn)分頁,select * from 表名 limit 開始記錄數(shù), 顯示多少條; 就可以實現(xiàn)我們的分頁效果。

但是在 oracle 中沒有 limit 關(guān)鍵字,但是有 rownum 字段

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

第一種:

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

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

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

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

第二種:

復(fù)制代碼 代碼如下:select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r 21 and e1.r

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

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

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

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

SqlServer:

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

語句形式:

復(fù)制代碼 代碼如下:
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 頁大小 * 頁數(shù) id

FROM 表

ORDER BY id))

ORDER BY ID

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

語句形式:

復(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 頁大小 *

FROM TestTable

WHERE (ID

(SELECT MAX(id)

FROM (SELECT TOP 頁大小 * 頁數(shù) id

FROM 表

ORDER BY id) AS T))

ORDER BY ID

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

復(fù)制代碼 代碼如下:
create procedure XiaoZhengGe

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

@currentpage int, – 第 N 頁

@pagesize int – 每頁行數(shù)

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 總頁數(shù) –,@rowcount as 總行數(shù),@currentpage as 當前頁

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

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

exec sp_cursorclose @P1

set nocount off

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

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

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

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

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

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

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

到此,關(guān)于“oracle、mysql 和 SqlServer 三種數(shù)據(jù)庫的分頁查詢實例”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注丸趣 TV 網(wǎng)站,丸趣 TV 小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-07-28發(fā)表,共計2626字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 项城市| 镇原县| 响水县| 吉林省| 洪江市| 当阳市| 河池市| 江川县| 郎溪县| 彭州市| 郧西县| 瑞昌市| 伊宁市| 武山县| 连山| 北流市| 芜湖市| 吴堡县| 安阳市| 台湾省| 白山市| 阜平县| 黄冈市| 绵竹市| 成安县| 玉环县| 城口县| 调兵山市| 卢氏县| 大埔县| 日土县| 和静县| 苍南县| 闽清县| 和龙市| 三河市| 巴马| 龙门县| 肃宁县| 蓬溪县| 昔阳县|