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

MySQL游標(biāo)的使用方式

 更新時間:2024年01月31日 09:44:36   作者:pan_junbiao  
這篇文章主要介紹了MySQL游標(biāo)的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

通過MySQL查詢數(shù)據(jù)庫,其結(jié)果可能為多條記錄。在存儲過程和函數(shù)中使用游標(biāo)可以實現(xiàn)逐條讀取結(jié)果集中的記錄。

游標(biāo)的使用包括聲明游標(biāo)(DECLARE CURSOR)、打開游標(biāo)(OPEN CURSOR)、使用游標(biāo)(FETCH CURSOR)和關(guān)閉游標(biāo)(CLOSE CURSOR)。

值得一提的是,MySQL游標(biāo)只能在存儲過程和存儲函數(shù)中使用。

游標(biāo)必須聲明在處理程序之前,且聲明在標(biāo)量和條件之后,即順序:變量定義-游標(biāo)定義-處理程序。

1、聲明游標(biāo)

在MySQL中,聲明游標(biāo)使用DECLARE關(guān)鍵字

其語法如下:

DECLARE cur_name CURSOR FOR select_statement

參數(shù)說明:

(1)cur_name:游標(biāo)的名稱。

(2)select_statement:是一個SELECT語句,返回一行或多行數(shù)據(jù),SELECT子句中不能包含INTO子句。

2、打開游標(biāo)

在聲明游標(biāo)之后,要從游標(biāo)中提取數(shù)據(jù),必須首先打開游標(biāo)。

在MySQL中使用OPEN關(guān)鍵字來打開游標(biāo)

其語法如下:

OPEN cur_name

3、使用游標(biāo)

游標(biāo)在順利打開后,可以使用FETCH...INTO語句來讀取數(shù)據(jù)

其語法如下:

FETCH cur_name INTO var_name[,var_name]...

其中,var_name是存放數(shù)據(jù)的標(biāo)量。

4、關(guān)閉游標(biāo)

游標(biāo)使用完畢后,要及時關(guān)閉,在MySQL中使用CLOST關(guān)鍵字來關(guān)閉游標(biāo)

其語法如下:

CLOSE cur_name

說明:

對于已關(guān)閉的游標(biāo),在其關(guān)閉之后則不能使用FETCH來使用游標(biāo)。游標(biāo)在使用完畢后一定要關(guān)閉。

示例:

在存儲過程中,使用游標(biāo)讀取用戶信息表中的數(shù)據(jù)。

(1)先創(chuàng)建tb_user(用戶信息表),并添加數(shù)據(jù)。

-- 創(chuàng)建用戶信息表
CREATE TABLE IF NOT EXISTS tb_user
(
	id INT AUTO_INCREMENT PRIMARY KEY COMMENT '用戶編號',
	name VARCHAR(50) NOT NULL COMMENT '用戶姓名'
) COMMENT = '用戶信息表';
 
-- 添加數(shù)據(jù)
INSERT INTO tb_user(name) VALUES('pan_junbiao的博客');
INSERT INTO tb_user(name) VALUES('KevinPan');
INSERT INTO tb_user(name) VALUES('pan_junbiao');
INSERT INTO tb_user(name) VALUES('阿標(biāo)');
INSERT INTO tb_user(name) VALUES('panjunbiao');
INSERT INTO tb_user(name) VALUES('pan_junbiao的CSDN博客');
INSERT INTO tb_user(name) VALUES('https://blog.csdn.net/pan_junbiao');

查詢數(shù)據(jù)結(jié)果:

(2)創(chuàng)建存儲過程,并使用游標(biāo)讀取用戶信息表中的數(shù)據(jù)。

-- 創(chuàng)建存儲過程
DROP PROCEDURE IF EXISTS proc_user;
CREATE PROCEDURE proc_user()
BEGIN
	DECLARE id INT;
	DECLARE name VARCHAR(50);
	
	-- 申明游標(biāo)
	DECLARE cur_user CURSOR FOR 
		SELECT * FROM tb_user;
 
	-- MySQL游標(biāo)異常后捕捉并設(shè)置循環(huán)使用變量id為null跳出循環(huán)。
	-- 注意:這段代碼要放在申明游標(biāo)的后面
	DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET id = NULL; 
	-- 或者:DECLARE CONTINUE HANDLER FOR NOT FOUND SET id = null;
 
	-- 打開游標(biāo)
	OPEN cur_user;
 
	-- 使用游標(biāo)
	FETCH cur_user INTO id,name;
 
	-- 使用WHILE循環(huán)讀取數(shù)據(jù)
	WHILE (id IS NOT NULL) DO
		-- 輸出內(nèi)容
		SELECT CONCAT('用戶編號:',id,' 用戶姓名:',name);
		
		-- 游標(biāo)讀取下一行記錄
		FETCH cur_user INTO id,name;
	END WHILE;
 
	-- 關(guān)閉游標(biāo)
	CLOSE cur_user;
END;

(3)調(diào)用存儲過程。

-- 調(diào)用存儲過程
CALL proc_user;

解釋說明:

DECLARE CONTINUE HANDLER FOR NOT FOUND 語句:

在mysql的存儲過程中經(jīng)常會看到這句話:DECLARE CONTINUE HANDLER FOR NOT FOUND。

它的含義是:若沒有數(shù)據(jù)返回,程序繼續(xù),并將變量 IS_FOUND 設(shè)為0 ,這種情況是出現(xiàn)在 select XX into XXX from tablename的時候發(fā)生的。

執(zhí)行結(jié)果:

示例:

使用LOOP循環(huán)語句,讀取游標(biāo)數(shù)據(jù)。

-- 創(chuàng)建存儲過程
DROP PROCEDURE proc_user;
CREATE PROCEDURE proc_user()
BEGIN
	DECLARE id INT;
	DECLARE name VARCHAR(50);
	
	-- 申明游標(biāo)
	DECLARE cur_user CURSOR FOR 
		SELECT * FROM tb_user;
 
	-- MySQL游標(biāo)異常后捕捉并設(shè)置循環(huán)使用變量id為null跳出循環(huán)。
	-- 注意:這段代碼要放在申明游標(biāo)的后面
	-- DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET id = NULL; 
	DECLARE CONTINUE HANDLER FOR NOT FOUND SET id = null;
 
	-- 打開游標(biāo)
	OPEN cur_user;
 
	-- 使用LOOP循環(huán)讀取數(shù)據(jù)
	loop_label:LOOP
		
		-- 使用游標(biāo)(讀取下一行記錄)
		FETCH cur_user INTO id,name;
		
		IF id IS NOT NULL THEN
			-- 輸出內(nèi)容
			SELECT CONCAT('用戶編號:',id,' 用戶姓名:',name);
		ELSE 
			-- 退出LOOP循環(huán)
			LEAVE loop_label;  
		END IF;
 
	END LOOP;		
 
	-- 關(guān)閉游標(biāo)
	CLOSE cur_user;
END;

執(zhí)行結(jié)果:

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL中文亂碼問題解決方案

    MySQL中文亂碼問題解決方案

    這篇文章主要介紹了MySQL中文亂碼問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • mysql中DATE_FORMAT()函數(shù)的具體使用

    mysql中DATE_FORMAT()函數(shù)的具體使用

    在MySQL中,DATE_FORMAT()函數(shù)用于將日期/時間類型的值按照指定的格式進(jìn)行格式化輸出,具有一定的參考價值,感興趣的可以了解一下
    2024-05-05
  • MySQL事務(wù)處理與應(yīng)用簡析

    MySQL事務(wù)處理與應(yīng)用簡析

    事務(wù)處理在各種管理系統(tǒng)中都有著廣泛的應(yīng)用,比如人員管理系統(tǒng),很多同步數(shù)據(jù)庫操作大都需要用到事務(wù)處理。這篇文章主要介紹了MySQL事務(wù)處理,需要的朋友可以參考下
    2014-06-06
  • MySQL高可用架構(gòu)之MHA架構(gòu)全解

    MySQL高可用架構(gòu)之MHA架構(gòu)全解

    MHA(Master HA)是一款開源的 MySQL 的高可用程序,它為 MySQL 主從復(fù)制架構(gòu)提供了 automating master failover 功能,本文重點給大家介紹MySQL高可用架構(gòu)之MHA架構(gòu)全解,感興趣的朋友一起看看吧
    2021-07-07
  • 連接MySQL出現(xiàn)Host is not allowed to connect to this MySQL server 解決方法詳解

    連接MySQL出現(xiàn)Host is not allowed to con

    這篇文章主要給大家介紹了連接MySQL出現(xiàn)Host is not allowed to connect to this MySQL server 解決方法,文中有詳細(xì)的解決步驟,需要的朋友可以參考下
    2023-08-08
  • mysql8.0.20下載安裝及遇到的問題(圖文詳解)

    mysql8.0.20下載安裝及遇到的問題(圖文詳解)

    這篇文章主要介紹了mysql8.0.20下載安裝及遇到的問題,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • mysql8.0無法使用group by的問題及解決

    mysql8.0無法使用group by的問題及解決

    這篇文章主要介紹了mysql8.0無法使用group by的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力

    MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力

    這篇文章主要為大家介紹了MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力的技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • 一文詳解如何徹底刪除舊版本mysql并安裝新版本

    一文詳解如何徹底刪除舊版本mysql并安裝新版本

    如果要重新安裝MySQL就必須將之前的MySQL進(jìn)行徹底的卸載,下面這篇文章主要給大家介紹了關(guān)于如何徹底刪除舊版本mysql并安裝新版本的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • MACOS中忘記MySQL root密碼的解決方案

    MACOS中忘記MySQL root密碼的解決方案

    這篇文章主要向大家講述的是在MAC系統(tǒng)中MySQL重設(shè)root密碼的實際操作步驟,在實際操作中忘記MySQL root密碼時常會發(fā)生的,下面就是本教程的詳細(xì)內(nèi)容介紹。
    2017-03-03

最新評論