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中DATE_FORMAT()函數(shù)的具體使用
在MySQL中,DATE_FORMAT()函數(shù)用于將日期/時間類型的值按照指定的格式進(jìn)行格式化輸出,具有一定的參考價值,感興趣的可以了解一下2024-05-05連接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-08MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力
這篇文章主要為大家介紹了MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力的技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05