MySQL游標(biāo)的使用方式
通過(guò)MySQL查詢數(shù)據(jù)庫(kù),其結(jié)果可能為多條記錄。在存儲(chǔ)過(guò)程和函數(shù)中使用游標(biāo)可以實(shí)現(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)只能在存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)中使用。
游標(biāo)必須聲明在處理程序之前,且聲明在標(biāo)量和條件之后,即順序:變量定義-游標(biāo)定義-處理程序。
1、聲明游標(biāo)
在MySQL中,聲明游標(biāo)使用DECLARE關(guān)鍵字
其語(yǔ)法如下:
DECLARE cur_name CURSOR FOR select_statement
參數(shù)說(shuō)明:
(1)cur_name:游標(biāo)的名稱。
(2)select_statement:是一個(gè)SELECT語(yǔ)句,返回一行或多行數(shù)據(jù),SELECT子句中不能包含INTO子句。
2、打開游標(biāo)
在聲明游標(biāo)之后,要從游標(biāo)中提取數(shù)據(jù),必須首先打開游標(biāo)。
在MySQL中使用OPEN關(guān)鍵字來(lái)打開游標(biāo)
其語(yǔ)法如下:
OPEN cur_name
3、使用游標(biāo)
游標(biāo)在順利打開后,可以使用FETCH...INTO語(yǔ)句來(lái)讀取數(shù)據(jù)
其語(yǔ)法如下:
FETCH cur_name INTO var_name[,var_name]...
其中,var_name是存放數(shù)據(jù)的標(biāo)量。
4、關(guān)閉游標(biāo)
游標(biāo)使用完畢后,要及時(shí)關(guān)閉,在MySQL中使用CLOST關(guān)鍵字來(lái)關(guān)閉游標(biāo)
其語(yǔ)法如下:
CLOSE cur_name
說(shuō)明:
對(duì)于已關(guān)閉的游標(biāo),在其關(guān)閉之后則不能使用FETCH來(lái)使用游標(biāo)。游標(biāo)在使用完畢后一定要關(guān)閉。
示例:
在存儲(chǔ)過(guò)程中,使用游標(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 '用戶編號(hào)',
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)建存儲(chǔ)過(guò)程,并使用游標(biāo)讀取用戶信息表中的數(shù)據(jù)。
-- 創(chuàng)建存儲(chǔ)過(guò)程
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('用戶編號(hào):',id,' 用戶姓名:',name);
-- 游標(biāo)讀取下一行記錄
FETCH cur_user INTO id,name;
END WHILE;
-- 關(guān)閉游標(biāo)
CLOSE cur_user;
END;(3)調(diào)用存儲(chǔ)過(guò)程。
-- 調(diào)用存儲(chǔ)過(guò)程 CALL proc_user;
解釋說(shuō)明:
DECLARE CONTINUE HANDLER FOR NOT FOUND 語(yǔ)句:
在mysql的存儲(chǔ)過(guò)程中經(jīng)常會(huì)看到這句話:DECLARE CONTINUE HANDLER FOR NOT FOUND。
它的含義是:若沒(méi)有數(shù)據(jù)返回,程序繼續(xù),并將變量 IS_FOUND 設(shè)為0 ,這種情況是出現(xiàn)在 select XX into XXX from tablename的時(shí)候發(fā)生的。
執(zhí)行結(jié)果:

示例:
使用LOOP循環(huán)語(yǔ)句,讀取游標(biāo)數(shù)據(jù)。
-- 創(chuàng)建存儲(chǔ)過(guò)程
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('用戶編號(hào):',id,' 用戶姓名:',name);
ELSE
-- 退出LOOP循環(huán)
LEAVE loop_label;
END IF;
END LOOP;
-- 關(guān)閉游標(biāo)
CLOSE cur_user;
END;執(zhí)行結(jié)果:

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql中DATE_FORMAT()函數(shù)的具體使用
在MySQL中,DATE_FORMAT()函數(shù)用于將日期/時(shí)間類型的值按照指定的格式進(jìn)行格式化輸出,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05
MySQL事務(wù)處理與應(yīng)用簡(jiǎn)析
事務(wù)處理在各種管理系統(tǒng)中都有著廣泛的應(yīng)用,比如人員管理系統(tǒng),很多同步數(shù)據(jù)庫(kù)操作大都需要用到事務(wù)處理。這篇文章主要介紹了MySQL事務(wù)處理,需要的朋友可以參考下2014-06-06
連接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下載安裝及遇到的問(wèn)題(圖文詳解)
這篇文章主要介紹了mysql8.0.20下載安裝及遇到的問(wèn)題,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
mysql8.0無(wú)法使用group by的問(wèn)題及解決
這篇文章主要介紹了mysql8.0無(wú)法使用group by的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫(kù)壓力
這篇文章主要為大家介紹了MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫(kù)壓力的技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05

