好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > oracle,mysql,SqlServer三種數據庫的分頁查詢的實例

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

熱門標簽:怎么給高德做地圖標注 榕城市地圖標注 北京400電話辦理多少錢 慶陽地圖標注 承德地圖標注公司名需要花錢嗎 浙江穩定外呼系統供應商 咸陽電腦外呼系統運營商 美團地圖標注商戶認證注冊 電銷外呼系統軟件功能

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的游標存儲過程分頁) 效率最差,但是最為通用

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

您可能感興趣的文章:
  • ADO.NET 連接數據庫字符串小結(Oracle、SqlServer、Access、ODBC)
  • c#幾種數據庫的大數據批量插入(SqlServer、Oracle、SQLite和MySql)
  • SQL獲取第一條記錄的方法(sqlserver、oracle、mysql數據庫)
  • sqlserver、Mysql、Oracle三種數據庫的優缺點總結
  • sqlserver實現oracle的sequence方法
  • 深入Mysql,SqlServer,Oracle主鍵自動增長的設置詳解
  • oracle連接ODBC sqlserver數據源的詳細步驟

標簽:呼和浩特 江蘇 新鄉 拉薩 昭通 貴州 重慶 上海

巨人網絡通訊聲明:本文標題《oracle,mysql,SqlServer三種數據庫的分頁查詢的實例》,本文關鍵詞  oracle,mysql,SqlServer,三種,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle,mysql,SqlServer三種數據庫的分頁查詢的實例》相關的同類信息!
  • 本頁收集關于oracle,mysql,SqlServer三種數據庫的分頁查詢的實例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 工囗番成人漫画全彩无遮在线观看 | 乳揉みま痴汉电车动漫中文字幕| 成熟女人自由XXX视频在| 少妇一边喂奶一边跟我做| 性插视频| 被啪的最爽的一次自述| 伊人成色综合人夜夜久久| 色秘?乱码一区二区三区唱戏| 污黄视频在线看| 99国精产品一区二区三区A片 | 双乳奶水被老汉吸呻吟视频| 雅典娜含精肉臀迎合娇吟小说| 国产成人精品亚洲AV女性| 《性船》菲律宾无删减| 情欲春宵课k8电影| 日本一区二区不卡久久入口| 开高中女学生小嫩苞的小说| 男女乱婬真人免费视频A片京东 | 一区二区三区中文字幕免费高清| 台湾R级艳片巜合欢宗| 厨房里退掉短裙| 欧美一区二区三区在线| а√天堂资源地址在线观看| 老师脱??让学生摸??| 妇乱子伦精品小说588| 粗壮公么进入让我| 香港三级88久久经典| 好男人www在线观看免费| 处破女处破全过第一次| 国产黄色毛片视频| 男人桶女人羞羞漫画| jlzzjlz亚洲女人高潮| 97狠狠色丁香婷婷综合久久 | 亚洲黄色在线播放| 欧美vps与windows性能比较1| 国产精品被???熟女| 小早川怜子精品视频| 公息肉浴秀婷| 青青草精品视频| 国产一级特黄AAA片奶水流| 竹菊国产AV影视在线|