Oracle 資料庫中對記錄進行分頁處理——學習筆記

来源:http://www.cnblogs.com/redirectZmh/archive/2016/12/12/6165319.html
-Advertisement-
Play Games

學習到 oracle 的視圖的時候,瞭解到對 Oracle 中數據的記錄進行分頁處理和 Mysql 提供的 limit 來進行分頁處理大有不同,limit 是 mysql 中特有的關鍵字。 那麼在 oracle 中如何實現對記錄的分頁處理呢? 解決辦法:使用 ROWNUM 1.問題如下:查詢出成績前 ...


  學習到 oracle 的視圖的時候,瞭解到對 Oracle 中數據的記錄進行分頁處理和 Mysql 提供的 limit 來進行分頁處理大有不同,limit 是 mysql 中特有的關鍵字。

  那麼在 oracle 中如何實現對記錄的分頁處理呢?

  解決辦法:使用 ROWNUM 

1.問題如下:查詢出成績前10名的學生的成績

  

  

SELECT name, score
FROM (SELECT name,score
    FROM students
      ORDER BY score DESC
    )
WHERE rownum <= 10

分析:先對其進行降序排序,然後從中查詢出 rownum 前10的記錄

需要註意得是:ROWNUM 只能使用 < 或 <=, 而是用 =, >, >= 都將不能返回任何數據.(沒有結果)

2.要查詢11名到20名學生的成績呢?

  由於 ROWNUM 不能使用> 和 >= 操作符

  那麼我們可以將上面的查詢結果在查一遍

  

SELECT name,score
FROM(SELECT ROWNUM rn, name,score
      FROM(SELECT name,score
                   FROM students
                   ORDER BY score DESC
                   )
          )
WHERE rn>10 AND rn<=20

 

這樣我們就得到了排序後的第11條到第12條記錄

 


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

-Advertisement-
Play Games
更多相關文章
  • ➠更多技術乾貨請戳:聽雲博客 動態鏈接 要解決空間浪費和更新困難這兩個問題最簡單的方法就是把程式的模塊相互分割開來,形成獨立的文件,而不再將它們靜態的鏈接在一起。簡單地講,就是不對那些組成程式的目標文件進行鏈接,等到程式要運行時才進行鏈接。也就是說,把鏈接過程推遲到了運行時再進行,這就是 _動態鏈接 ...
  • 示例一:實現通知欄管理 當針對相同類型的事件多次發出通知,作為開發者,應該避免使用全新的通知,這時就應該考慮更新之前通知欄的一些值來達到提醒用戶的目的。例如我們手機的簡訊系統,當不斷有新消息傳來時,我們的通知欄僅僅是更改傳來簡訊的數目,而不是對每條簡訊單獨做一個通知欄用於提示。 修改通知 可以設置一 ...
  • 今天在寫微信登錄,花了半天時間搞定、然後寫下自己的筆記,希望幫助更多的人。。。歡迎各位指教。 微信授權登錄,官方說的不是很清楚、所以導致有一部分的坑。 微信註冊應用平臺的應用簽名,下載 微信簽名生成工具 輸入項目的packageName也可以查看到。 (註意:debug、Release 一定要區分, ...
  • 在SQL Server中導入數據時,會有一個“啟用標示插入”的選項,突然間懵逼了,這到底啥意思?我選與不選這個選項,結果好像沒區別!不科學啊這,“存在即合理”,我相信這個選項肯定有它的用處,只是我不知道罷了。 於是我去查資料,在CSDN論壇里找到了可能的解釋: 1)首先:“啟用標示插入”只對標示列( ...
  • 事務 事務是作為單個邏輯工作單元執行的一系列操作。一個邏輯工作單元必須有四個屬性,稱為原子性、一致性、隔離性和持久性 (ACID) 屬性,只有這樣才能成為一個事務。 事務併發 資料庫是多個用戶(事務)共用的,當多個用戶同時訪問數據時,那麼在這種情況下就叫做併發。 事務併發下可能出現的問題 更新丟失 ...
  • oracle資料庫中,數據的增、刪、改、查,通過SQL語句實現 SQL:結構化查詢語言; 特點:不區分大小寫;字元串用單引號引起來;語句結束用分號表示結束; 行註釋,在語句的最前面加“--” 塊註釋,分別在語句的前後加 /* 和 */ SQL中常用的幾類: 一、數據定義語言 DDL:創建、修改、刪除 ...
  • 最近在入門nodejs,正好學習到瞭如何使用nodejs進行資料庫的連接,覺得比較重要,便寫一下隨筆,簡單地記錄一下 使用在安裝好node之後,我們可以使用npm命令,在項目的根目錄,安裝nodejs中的mysql模塊 在連接資料庫之前,要先引入nodejs連接處理mysql的模塊 類似php連接m ...
  • 類型 行級觸發器: FOR EACH ROW 影響的每一行都會執行觸發器 語句級出發器 預設的模式,一句話才執行一次觸發器 觸發器不能嵌套,不能含有事務控制語句 何時觸發 Before:條件運行前 After:條件運行後 Instead of:替代觸發,作用在視圖上 創建觸發器 實例一 1.創建一個 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...