轉Oracle、MySql、SQLServer 數據分頁查詢

来源:http://www.cnblogs.com/hesijian/archive/2016/08/18/5782468.html
-Advertisement-
Play Games

最近簡單的對oracle,mysql,sqlserver2005的數據分頁查詢作了研究,把各自的查詢的語句貼出來供大家學習..... (一)、 mysql的分頁查詢 mysql的分頁查詢是最簡單的,藉助關鍵字limit即可實現查詢,查詢語句通式: 如下麵的截圖,每頁顯示的記錄數為20: 查詢(1-2 ...


  最近簡單的對oracle,mysql,sqlserver2005的數據分頁查詢作了研究,把各自的查詢的語句貼出來供大家學習.....

       (一)、 mysql的分頁查詢

        mysql的分頁查詢是最簡單的,藉助關鍵字limit即可實現查詢,查詢語句通式:

/*

* sql:可以是單表的查詢語句,也可以是多表的聯合查詢語句

* firstIndex:其實的索引

* pageSize:每頁顯示的記錄數

*/

select o.* from (sql) o limit firstIndex,pageSize

 

如下麵的截圖,每頁顯示的記錄數為20:

                                                  查詢(1-20)這20條記錄

                                             查詢(21-40)這20條記錄

        mysql的分頁查詢就這麼簡單......

 

(二)、sqlserver2005的分頁查詢

    在sqlserver2005之前一直藉助top關鍵字來實現分頁查詢,不過效率低,在sqlserver2005及其之後的版本都使用row_number()解析函數來完成分頁查詢,效率有了很大的提高,不過sql語句比較複雜,下麵給出分頁查詢的通式:

 

/*

* firstIndex:起始索引


* pageSize:每頁顯示的數量

* orderColumn:排序的欄位名

* sql:可以是簡單的單表查詢語句,也可以是複雜的多表聯合查詢語句

*/

select top pageSize o.* from (select row_number() over(order by orderColumn) as rownumber,* from(sql) as o where rownumber>firstIndex;

 下麵看截圖,每頁顯示20條記錄數:

                                                             查詢(1-20)這20條記錄

                                                         查詢(21-40)這20條記錄

    知道了sqlserver中的row_number函數,分頁也就簡單了.....

  (三)、oracle分頁查詢

    接下來重點說說oracle的分頁查詢,oracle的分頁查詢方法相對來說要多點,ROWNUM、row_number(),今天主要將兩種效率稍好的分頁查詢語句。

    ①ROWNUM查詢分頁通式:

 

 

/*

* firstIndex:起始索引

* pageSize:每頁顯示的數量

* sql:可以是簡單的單表查詢語句,也可以是複雜的多表聯合查詢語句

*/
select * from(select a.*,ROWNUM rn from(sql) a where ROWNUM<=(firstIndex+pageSize)) where rn>firstIndex

 

 

以下截圖是以這種方式進行的查詢語句:

                                                          查詢(1-21)這20條記錄*****(沒有ID=6的記錄,所以查詢到的最大ID為21)

                                                       查詢(22-41)這20條記錄*****(沒有ID=6的記錄,所以開始查詢到的ID為22,以及最大ID為41)

     ②row_number()解析函數分頁查詢通式:

/*

 * firstIndex:起始索引

 * pageSize:每頁顯示的數量

 * orderColumn:排序的欄位名

 * sql:可以是簡單的單表查詢語句,也可以是複雜的多表聯合查詢語句

 */
select * from(select * from(select t.*,row_number() over(order by orderColumn) as rownumber from(sql) t) p where p.rownumber>firstIndex) where rownum<=pageSize

 以下截圖是使用row_number()方式的分頁查詢效果:

                                                          查詢(1-21)這20條記錄*****(沒有ID=6的記錄,所以查詢到的最大ID為21)

                                                    查詢(22-41)這20條記錄*****(沒有ID=6的記錄,所以開始查詢到的ID為22,以及最大ID為41)

      對於oracle的分頁查詢,特地選出這兩種實現方式是因為這兩者各有千秋

     首先, 我們知道在ROWNUM查詢的方式中,在第二層的sql語句中有個"where ROWNUM<firstIndex+pageSize",根據oracle的原則,第二層查詢語句會嵌入到最內層中進行查詢,也就是說,最開始執行的查詢語句類似於:select * from wyuse where rownum<(firstIndex+pageSize) order by id asc,從數據表中查詢出(firstIndex+pageSize)條記錄,所以如果這個值很小的話,效率會很好,如果對於大數據量的表單,這個值如果是上千,比如:select * from wyuse where rownum<(5000) order by id asc,這樣一開始會選出5000條記錄,效率自然會慢很多....

     不過,相對於ROWNUM,row_number()方式可能通過簡化可以少一層嵌套,不過貌似對於大數量的查詢,效率也高不到哪裡去.....不過,對於大數量如果為表建立索引再結合row_number()效果會很好(未測試)

 

本文轉自:http://www.cnblogs.com/wangyong/p/3396333.html

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • android閃頻的實現非常簡單,使用Handler對象的postDelayed()方法就可以實現。在這個方法里傳遞一個Runnable對象和一個延遲的時間。該方法實現了一個延遲執行的效果,延遲的時間由第2個參數指定,單位是毫秒。第一個參數是Runnable對象,裡面包含了延遲後需要執行的操作。我在 ...
  • <!--?xml version="1.0" encoding="UTF-8" standalone="no"?--> 目前隨著公司開發模式的變更,swift也顯得越發重要,相對來說,swift語言更加簡潔,嚴謹.但對於我來說,感覺swift細節的處理很繁瑣,可能是還沒適應的緣故吧.基本每寫一句代碼 ...
  • 一、項目需求: 因為產品對象用於中老年人,所以產品設計添加了APP全局字體調整大小功能。 這裡仿做QQ設置字體大小的功能。 QQ實現的效果是,滾動下麵的seekbar,當只有seekbar到達某一個刻度的時候,這時候上部分的效果展示部分會改變文字大小, 但是在拖動過程中字體不會改變。關閉此界面,就可 ...
  • alloc -> initWithNibName -> loadView -> viewDidLoad -> viewWillAppear -> viewDidAppear -> viewWillDisappear -> viewDidDisappear -> dealloc 註意,不要在loadV ...
  • load 方法會在載入類的時候就被調用,也就是 ios 應用啟動的時候,就會載入所有的類,就會調用每個類的 + load 方法。 在沒有對類做任何操作的情況下,+load 方法會被預設執行,並且是在 main 函數之前執行的。程式啟動之前會調用 ...
  • [className new]基本等同於[[className alloc] init]; 區別隻在於alloc分配記憶體的時候使用了zone. 這個zone是個什麼東東呢? 它是給對象分配記憶體的時候,把關聯的對象分配到一個相鄰的記憶體區域內,以便於調用時消耗很少的代價,提升了程式處理速度; 如果使用n ...
  • 1:帶中文的URL處理 2:取WebView高度 3:UIView的部分圓角問題 4:強制App直接退出 5:修改占位符顏色和大小 6:取消系統的返回手勢 7:改WebView字體/顏色 UIWebView設置字體大小,顏色,字體: UIWebView無法通過自身的屬性設置字體的一些屬性,只能通過h ...
  • 純 HTML5 APP與原生APP的差距在哪? 寫過一些純H5的APP,雖然開發起來的確很快很舒服,但和原生比起來純H5APP還是有很多問題,主要聚集在以下幾個方面: 1、動畫 動畫有很多種,比如側邊欄菜單的滑入滑出、元素的響應動畫、頁面切換之間的過場等等,在H5之下的眾多實現方法都沒有辦法達到純原 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...