如何創建和使用 SQL 游標

来源:https://www.cnblogs.com/vin-c/archive/2022/05/19/16288637.html
-Advertisement-
Play Games

本文介紹什麼是 SQL 游標,為什麼使用游標,如何使用游標。你使用的 DBMS 可能會提供某種形式的游標,以及這裡沒有提及的功能。更詳細的內容請參閱具體的 DBMS 文檔。 一、游標 SQL 檢索操作返回一組稱為結果集的行,這組返回的行都是與 SQL 語句相匹配的行(零行到多行)。 簡單地使用 SE ...


目錄

本文介紹什麼是 SQL 游標,為什麼使用游標,如何使用游標。你使用的 DBMS 可能會提供某種形式的游標,以及這裡沒有提及的功能。更詳細的內容請參閱具體的 DBMS 文檔。

一、游標

SQL 檢索操作返回一組稱為結果集的行,這組返回的行都是與 SQL 語句相匹配的行(零行到多行)。

簡單地使用 SELECT 語句,沒有辦法得到第一行、下一行或前 10 行。但這是關係 DBMS 功能的組成部分。

結果集(result set)

SQL 查詢所檢索出的結果。

有時,需要在檢索出來的行中前進或後退一行或多行,這就是游標的用途所在。

游標(cursor)是一個存儲在 DBMS 伺服器上的資料庫查詢,它不是一條 SELECT 語句,而是被該語句檢索出來的結果集。

在存儲了游標之後,應用程式可以根據需要滾動或瀏覽其中的數據。

說明:SQLite 支持

SQLite 支持的游標稱為步驟(step),本文講述的基本概念適用於 SQLite 的步驟,但語法可能完全不同。

不同的 DBMS 支持不同的游標選項和特性。常見的一些選項和特性如下。

  • 能夠標記游標為只讀,使數據能讀取,但不能更新和刪除。
  • 能控制可以執行的定向操作(向前、向後、第一、最後、絕對位置和相對位置等)。
  • 能標記某些列為可編輯的,某些列為不可編輯的。
  • 規定範圍,使游標對創建它的特定請求(如存儲過程)或對所有請求可訪問。
  • 指示 DBMS 對檢索出的數據(而不是指出表中活動數據)進行複製,使數據在游標打開和訪問期間不變化。

游標主要用於互動式應用,其中用戶需要滾動屏幕上的數據,並對數據進行瀏覽或做出更改。

二、使用游標

使用游標涉及幾個明確的步驟。

  • 在使用游標前,必須聲明(定義)它。這個過程實際上沒有檢索數據,它只是定義要使用的 SELECT 語句和游標選項。
  • 一旦聲明,就必須打開游標以供使用。這個過程用前面定義的 SELECT 語句把數據實際檢索出來。
  • 對於填有數據的游標,根據需要取出(檢索)各行。
  • 在結束游標使用時,必須關閉游標,可能的話,釋放游標(有賴於具體的 DBMS)。

聲明游標後,可根據需要頻繁地打開和關閉游標。在游標打開時,可根據需要頻繁地執行取操作。

2.1 創建游標

使用 DECLARE 語句創建游標,這條語句在不同的 DBMS 中有所不同。

DECLARE 命名游標,並定義相應的 SELECT 語句,根據需要帶 WHERE 和其他子句。

為了說明,我們創建一個游標來檢索沒有電子郵件地址的所有顧客,作為應用程式的組成部分,幫助操作人員找出空缺的電子郵件地址。

下麵是創建此游標的 DB2、MariaDB、MySQL 和 SQL Server 版本。

DECLARE CustCursor CURSOR
FOR
SELECT * FROM Customers
WHERE cust_email IS NULL;

下麵是 Oracle 和 PostgreSQL 版本:

DECLARE CURSOR CustCursor
IS
SELECT * FROM Customers
WHERE cust_email IS NULL;

在上面兩個版本中,DECLARE 語句用來定義和命名游標,這裡為 CustCursorSELECT 語句定義一個包含沒有電子郵件地址(NULL 值)的所有顧客的游標。

定義游標之後,就可以打開它了。

2.2 使用游標

使用 OPEN CURSOR 語句打開游標,這條語句很簡單,在大多數 DBMS 中的語法相同:

OPEN CURSOR CustCursor

在處理 OPEN CURSOR 語句時,執行查詢,存儲檢索出的數據以供瀏覽和滾動。

現在可以用 FETCH 語句訪問游標數據了。FETCH 指出要檢索哪些行,從何處檢索它們以及將它們放於何處(如變數名)。

第一個例子使用 Oracle 語法從游標中檢索一行(第一行):

DECLARE TYPE CustCursor IS REF CURSOR
    RETURN Customers%ROWTYPE;
DECLARE CustRecord Customers%ROWTYPE
BEGIN
    OPEN CustCursor;
    FETCH CustCursor INTO CustRecord;
    CLOSE CustCursor;
END;

在這個例子中,FETCH 用來檢索當前行(自動從第一行開始),放到聲明的變數 CustRecord 中。對於檢索出來的數據不做任何處理。

下一個例子(也使用 Oracle 語法)中,從第一行到最後一行,對檢索出來的數據進行迴圈:

DECLARE TYPE CustCursor IS REF CURSOR
    RETURN Customers%ROWTYPE;
DECLARE CustRecord Customers%ROWTYPE
BEGIN
    OPEN CustCursor;
    LOOP
    FETCH CustCursor INTO CustRecord;
    EXIT WHEN CustCursor%NOTFOUND;
       ...
    END LOOP;
    CLOSE CustCursor;
END;

與前一個例子一樣,這個例子使用 FETCH 檢索當前行,放到一個名為 CustRecord 的變數中。

但不一樣的是,這裡的 FETCH 位於 LOOP 內,因此它反覆執行。

代碼 EXIT WHEN CustCursor%NOTFOUND 使在取不出更多的行時終止處理(退出迴圈)。

這個例子也沒有做實際的處理,實際例子中可用具體的處理代碼替換省略號。

下麵是另一個例子,這次使用 Microsoft SQL Server 語法:

DECLARE @cust_id CHAR(10),
        @cust_name CHAR(50),
        @cust_address CHAR(50),
        @cust_city CHAR(50),
        @cust_state CHAR(5),
        @cust_zip CHAR(10),
        @cust_country CHAR(50),
        @cust_contact CHAR(50),
        @cust_email CHAR(255)
OPEN CustCursor
FETCH NEXT FROM CustCursor
    INTO @cust_id, @cust_name, @cust_address,
         @cust_city, @cust_state, @cust_zip,
         @cust_country, @cust_contact, @cust_email
   ...
WHILE @@FETCH_STATUS = 0
BEGIN

FETCH NEXT FROM CustCursor
        INTO @cust_id, @cust_name, @cust_address,
             @cust_city, @cust_state, @cust_zip,
             @cust_country, @cust_contact, @cust_email
...
END
CLOSE CustCursor

在此例中,為每個檢索出的列聲明一個變數,FETCH 語句檢索一行並保存值到這些變數中。

使用 WHILE 迴圈處理每一行,條件 WHILE @@FETCH_STATUS = 0 在取不出更多的行時終止處理(退出迴圈)。

這個例子也不進行具體的處理,實際代碼中,應該用具體的處理代碼替換其中的“...”。

2.3 關閉游標

如前面幾個例子所述,游標在使用完畢時需要關閉。此外,SQL Server 等 DBMS 要求明確釋放游標所占用的資源。

下麵是 DB2、Oracle 和 PostgreSQL 的語法。

CLOSE CustCursor

下麵是 Microsoft SQL Server 的版本。

CLOSE CustCursor
DEALLOCATE CURSOR CustCursor

CLOSE 語句用來關閉游標。一旦游標關閉,如果不再次打開,將不能使用。第二次使用它時不需要再聲明,只需用 OPEN 打開它即可。

三、小結

本文介紹了什麼是游標,為什麼使用游標。

你使用的 DBMS 可能會提供某種形式的游標,以及這裡沒有提及的功能。更詳細的內容請參閱具體的 DBMS 文檔。

原文鏈接:https://www.developerastrid.com/sql/sql-cursor/

(完)


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

-Advertisement-
Play Games
更多相關文章
  • 本文例子參考《STM32單片機開發實例——基於Proteus虛擬模擬與HAL/LL庫》 源代碼:https://github.com/LanLinnet/STM33F103R6 項目要求 單片機將由串口收到的1位元組數據存入Flash ROM的指定地址;按下按鈕BTN,單片機將存儲在Flash ROM ...
  • 為什麼要使用Redwood Redwood是一個全棧web框架,旨在幫助你從副業項目發展到創業。Redwood的特色是一個端到端的開發工作流,它將React、GraphQL、Prisma、TypeScript、Jest和Storybook中最好的部分編織在一起。 RedwoodJS 是集成 、Pri ...
  • Termius是微軟的一款SSH終端工具,它支持多平臺。而且操作界面十分ha好看且簡潔,今天分享給大家❤️ 軟體下載 關註下方公眾號,回覆termius獲取下載地址 軟體功能介紹 Termius Mac破解版是一款非常好用而且漂亮的SSH客戶端,能快速遠程式控制制伺服器,可以定製自己喜歡的主題,支持FT ...
  • 一、概述 Impala 直接針對存儲在 HDFS、HBase或 Amazon Simple Storage Service (S3)中的 Apache Hadoop 數據提供快速的互動式 SQL 查詢。Impala是一個基於Hive、分散式、大規模並行處理(MPP:Massively Paralle ...
  • 軟硬體環境 軟體 版本 操作系統 Redhat 7 及以上版本,麒麟V10 DM 資料庫 DM 8.0 及以上版本 CPU 架構 x86、ARM、龍芯、飛騰等國內外主流 CPU DM-Oracle 環境準備 在DM伺服器中完成Dblink環境準備工作。 配置Oracle oci客戶端 在Oracle ...
  • 導讀: 隨著全球數據量的不斷增長,越來越多的業務需要支撐高併發、高可用、可擴展、以及海量的數據存儲,在這種情況下,適應各種場景的數據存儲技術也不斷的產生和發展。與此同時,各種資料庫之間的同步與轉化的需求也不斷增多,數據集成成為大數據領域的熱門方向,於是SeaTunnel應運而生。SeaTunnel是 ...
  • hive 存儲格式有很多,但常用的一般是 TextFile、ORC、Parquet 格式,在我們單位最多的也是這三種 hive 預設的文件存儲格式是 TextFile。 除 TextFile 外的其他格式的表不能直接從本地文件導入數據,要先導入到 TextFile 格式的表中,再從表中用 inser ...
  • 本文介紹 SQL 所涉及的幾個數據處理特性:約束、索引和觸發器。約束是實施引用完整性的重要部分,索引可改善數據檢索的性能,觸發器可以用來執行運行前後的處理。 一、約束 SQL 已經改進過多個版本,成為非常完善和強大的語言。許多強有力的特性給用戶提供了高級的數據處理技術,如約束。 關聯表和引用完整性已 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...