欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql存儲過程之游標(DECLARE)原理與用法詳解

 更新時間:2019年12月26日 10:51:04   作者:luyaran  
這篇文章主要介紹了mysql存儲過程之游標(DECLARE)原理與用法,結(jié)合實例形式詳細分析了mysql存儲過程游標(DECLARE)的基本功能、原理、使用方法及操作注意事項,需要的朋友可以參考下

本文實例講述了mysql存儲過程之游標(DECLARE)原理與用法。分享給大家供大家參考,具體如下:

我們在處理存儲過程中的結(jié)果集時,可以使用游標,因為游標允許我們迭代查詢返回的一組行,并相應地處理每行。mysql的游標為只讀,不可滾動和敏感三種模式,我們來看下:

  • 只讀:無法通過光標更新基礎表中的數(shù)據(jù)。
  • 不可滾動:只能按照select語句確定的順序獲取行。不能以相反的順序獲取行。 此外,不能跳過行或跳轉(zhuǎn)到結(jié)果集中的特定行。
  • 敏感:有兩種游標:敏感游標和不敏感游標。敏感游標指向?qū)嶋H數(shù)據(jù),不敏感游標使用數(shù)據(jù)的臨時副本。敏感游標比一個不敏感的游標執(zhí)行得更快,因為它不需要臨時拷貝數(shù)據(jù)。但是,對其他連接的數(shù)據(jù)所做的任何更改都將影響由敏感游標使用的數(shù)據(jù),因此,如果不更新敏感游標所使用的數(shù)據(jù),則更安全。 MySQL游標是敏感的。

我們可以在存儲過程,存儲函數(shù)和觸發(fā)器中使用MySQL游標,咱們先來看下使用DECLARE語句聲明的語法:

DECLARE cursor_name CURSOR FOR SELECT_statement;

我們要注意下,游標聲明必須在變量聲明之后。如果在變量聲明之前聲明游標,mysql將會發(fā)出一個錯誤,另外游標必須始終與SELECT語句相關聯(lián)。完事呢,我們來使用OPEN語句打開游標。OPEN語句初始化游標的結(jié)果集,因此我們必須在從結(jié)果集中提取行之前調(diào)用OPEN語句:

OPEN cursor_name;

然后,我們來使用FETCH語句來檢索光標指向的下一行,并將光標移動到結(jié)果集中的下一行:

FETCH cursor_name INTO variables list;

之后,我們就可以檢查是否有任何行記錄可用,然后再提取它。完事最后還要記得調(diào)用CLOSE語句來停用光標并釋放與之關聯(lián)的內(nèi)存:

CLOSE cursor_name;

我們要知道,當光標不再使用時,應該關閉它。當我們使用mysql游標時,還必須聲明一個NOT FOUND處理程序來處理當游標找不到任何行時的情況。 因為每次調(diào)用FETCH語句時,游標會嘗試讀取結(jié)果集中的下一行。 當光標到達結(jié)果集的末尾時,它將無法獲得數(shù)據(jù),并且會產(chǎn)生一個條件。NOT FOUND處理程序用于處理這種情況,我們來看下它的語法結(jié)構:

DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;

finished是一個變量,指示光標到達結(jié)果集的結(jié)尾。請注意,處理程序聲明必須出現(xiàn)在存儲過程中的變量和游標聲明之后。我們再來看下mysql游標的運行原理圖:

咱們接下來,就要開發(fā)一個存儲過程用來獲取employees表中所有員工的電子郵件列表。我們先來聲明一些變量,一個用于循環(huán)員工電子郵件的游標和一個NOT FOUND處理程序:

DECLARE finished INTEGER DEFAULT 0;
DECLARE email varchar(255) DEFAULT "";
-- declare cursor for employee email
DEClARE email_cursor CURSOR FOR
 SELECT email FROM employees;
-- declare NOT FOUND handler
DECLARE CONTINUE HANDLER
FOR NOT FOUND SET finished = 1;
接下來,使用OPEN語句打開email_cursor:
OPEN email_cursor;

然后,迭代電子郵件列表,并使用分隔符(;)連接每個電子郵件:

get_email: LOOP
 FETCH email_cursor INTO v_email;
 IF v_finished = 1 THEN
 LEAVE get_email;
 END IF;
 -- build email list
 SET email_list = CONCAT(v_email,";",email_list);
END LOOP get_email;

之后,我們在循環(huán)中,使用v_finished變量來檢查列表中是否有任何電子郵件來終止循環(huán),完事呢,使用CLOSE語句關閉游標:

CLOSE email_cursor;

我們來看下build_email_list存儲過程所有代碼:

DELIMITER $$
CREATE PROCEDURE build_email_list (INOUT email_list varchar(4000))
BEGIN
 DECLARE v_finished INTEGER DEFAULT 0;
    DECLARE v_email varchar(100) DEFAULT "";
 -- declare cursor for employee email
 DEClARE email_cursor CURSOR FOR
 SELECT email FROM employees;
 -- declare NOT FOUND handler
 DECLARE CONTINUE HANDLER
    FOR NOT FOUND SET v_finished = 1;
 OPEN email_cursor;
 get_email: LOOP
 FETCH email_cursor INTO v_email;
 IF v_finished = 1 THEN
 LEAVE get_email;
 END IF;
 -- build email list
 SET email_list = CONCAT(v_email,";",email_list);
 END LOOP get_email;
 CLOSE email_cursor;
END$$
DELIMITER ;

我們來使用以下腳本測試build_email_list存儲過程:

SET @email_list = "";
CALL build_email_list(@email_list);
SELECT @email_list;

至于結(jié)果,咱就不贅述了哈。

更多關于MySQL相關內(nèi)容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》及《MySQL數(shù)據(jù)庫鎖相關技巧匯總

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

相關文章

  • mysql創(chuàng)建本地用戶及賦予數(shù)據(jù)庫權限的方法示例

    mysql創(chuàng)建本地用戶及賦予數(shù)據(jù)庫權限的方法示例

    這篇文章主要介紹了mysql創(chuàng)建本地用戶及賦予數(shù)據(jù)庫權限的相關資料,文中的介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-04-04
  • mysql備份腳本 mysqldump使用方法詳解

    mysql備份腳本 mysqldump使用方法詳解

    這篇文章主要為大家詳細介紹了mysql備份腳本(mysqldump),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Mysql優(yōu)化神器(推薦)

    Mysql優(yōu)化神器(推薦)

    這篇文章主要介紹了Mysql優(yōu)化神器(推薦),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • MySQL 5.7雙主同步部分表的實現(xiàn)過程詳解

    MySQL 5.7雙主同步部分表的實現(xiàn)過程詳解

    這篇文章主要給大家介紹了關于MySQL 5.7雙主同步部分表實現(xiàn)的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-09-09
  • SQL NULL值的定義測試處理空數(shù)據(jù)及SQL?UPDATE語句使用詳解

    SQL NULL值的定義測試處理空數(shù)據(jù)及SQL?UPDATE語句使用詳解

    這篇文章主要為大家介紹了SQL NULL值的定義測試處理空數(shù)據(jù)及SQL?UPDATE語句使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • mysql語法之DQL操作詳解

    mysql語法之DQL操作詳解

    大家好,本篇文章主要講的是mysql語法之DQL操作詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • 幾個MySQL高頻面試題的解答

    幾個MySQL高頻面試題的解答

    這篇文章主要介紹了幾個MySQL高頻面試題的解答,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2021-01-01
  • MySQL中int(10)和int(11)的區(qū)別詳解

    MySQL中int(10)和int(11)的區(qū)別詳解

    本文主要介紹了MySQL中int(10)和int(11)的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • 在數(shù)據(jù)庫里將毫秒轉(zhuǎn)換成date格式的方法

    在數(shù)據(jù)庫里將毫秒轉(zhuǎn)換成date格式的方法

    經(jīng)常會將日期時間的毫秒數(shù)存放到數(shù)據(jù)庫,但是它對應的時間看起來就十分不方便,可以使用一些函數(shù)將毫秒轉(zhuǎn)換成date格式
    2014-05-05
  • mysql server 5.7.20 安裝配置方法圖文教程

    mysql server 5.7.20 安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql server 5.7.20 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09

最新評論