MySQL游標的使用方式
通過MySQL查詢數(shù)據(jù)庫,其結(jié)果可能為多條記錄。在存儲過程和函數(shù)中使用游標可以實現(xiàn)逐條讀取結(jié)果集中的記錄。
游標的使用包括聲明游標(DECLARE CURSOR)、打開游標(OPEN CURSOR)、使用游標(FETCH CURSOR)和關(guān)閉游標(CLOSE CURSOR)。
值得一提的是,MySQL游標只能在存儲過程和存儲函數(shù)中使用。
游標必須聲明在處理程序之前,且聲明在標量和條件之后,即順序:變量定義-游標定義-處理程序。
1、聲明游標
在MySQL中,聲明游標使用DECLARE關(guān)鍵字
其語法如下:
DECLARE cur_name CURSOR FOR select_statement
參數(shù)說明:
(1)cur_name:游標的名稱。
(2)select_statement:是一個SELECT語句,返回一行或多行數(shù)據(jù),SELECT子句中不能包含INTO子句。
2、打開游標
在聲明游標之后,要從游標中提取數(shù)據(jù),必須首先打開游標。
在MySQL中使用OPEN關(guān)鍵字來打開游標
其語法如下:
OPEN cur_name
3、使用游標
游標在順利打開后,可以使用FETCH...INTO語句來讀取數(shù)據(jù)
其語法如下:
FETCH cur_name INTO var_name[,var_name]...
其中,var_name是存放數(shù)據(jù)的標量。
4、關(guān)閉游標
游標使用完畢后,要及時關(guān)閉,在MySQL中使用CLOST關(guān)鍵字來關(guān)閉游標
其語法如下:
CLOSE cur_name
說明:
對于已關(guān)閉的游標,在其關(guān)閉之后則不能使用FETCH來使用游標。游標在使用完畢后一定要關(guān)閉。
示例:
在存儲過程中,使用游標讀取用戶信息表中的數(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('阿標');
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)建存儲過程,并使用游標讀取用戶信息表中的數(shù)據(jù)。
-- 創(chuàng)建存儲過程
DROP PROCEDURE IF EXISTS proc_user;
CREATE PROCEDURE proc_user()
BEGIN
DECLARE id INT;
DECLARE name VARCHAR(50);
-- 申明游標
DECLARE cur_user CURSOR FOR
SELECT * FROM tb_user;
-- MySQL游標異常后捕捉并設(shè)置循環(huán)使用變量id為null跳出循環(huán)。
-- 注意:這段代碼要放在申明游標的后面
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET id = NULL;
-- 或者:DECLARE CONTINUE HANDLER FOR NOT FOUND SET id = null;
-- 打開游標
OPEN cur_user;
-- 使用游標
FETCH cur_user INTO id,name;
-- 使用WHILE循環(huán)讀取數(shù)據(jù)
WHILE (id IS NOT NULL) DO
-- 輸出內(nèi)容
SELECT CONCAT('用戶編號:',id,' 用戶姓名:',name);
-- 游標讀取下一行記錄
FETCH cur_user INTO id,name;
END WHILE;
-- 關(guān)閉游標
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)語句,讀取游標數(shù)據(jù)。
-- 創(chuàng)建存儲過程
DROP PROCEDURE proc_user;
CREATE PROCEDURE proc_user()
BEGIN
DECLARE id INT;
DECLARE name VARCHAR(50);
-- 申明游標
DECLARE cur_user CURSOR FOR
SELECT * FROM tb_user;
-- MySQL游標異常后捕捉并設(shè)置循環(huán)使用變量id為null跳出循環(huán)。
-- 注意:這段代碼要放在申明游標的后面
-- DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET id = NULL;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET id = null;
-- 打開游標
OPEN cur_user;
-- 使用LOOP循環(huán)讀取數(shù)據(jù)
loop_label:LOOP
-- 使用游標(讀取下一行記錄)
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)閉游標
CLOSE cur_user;
END;執(zhí)行結(jié)果:

總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql中DATE_FORMAT()函數(shù)的具體使用
在MySQL中,DATE_FORMAT()函數(shù)用于將日期/時間類型的值按照指定的格式進行格式化輸出,具有一定的參考價值,感興趣的可以了解一下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 解決方法,文中有詳細的解決步驟,需要的朋友可以參考下2023-08-08
MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力
這篇文章主要為大家介紹了MySQL做讀寫分離提高性能緩解數(shù)據(jù)庫壓力的技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05

