MySQL 游標(biāo)的具體使用方案
以下的文章主要描述的是MySQL 游標(biāo)的具體使用方案,如果你對(duì)MySQL 游標(biāo)的實(shí)際操作有興趣的話,你就可以對(duì)以下的文章點(diǎn)擊觀看了,希望在你瀏覽之后會(huì)給你帶來(lái)一些幫助在此方面。
請(qǐng)使用 MySQL 1.5 或以上version;
測(cè)試表 level ;
- create table test.level (name varchar(20));
再 insert 些數(shù)據(jù) ;
代碼
初始化
drop procedure if exists useCursor //
建立 存儲(chǔ)過(guò)程 create
CREATE PROCEDURE useCursor()
BEGIN
局部變量的定義 declare
- declare tmpName varchar(20) default '' ;
- declare allName varchar(255) default '' ;
- declare cur1 CURSOR FOR SELECT name FROM test.level ;
MySQL 不知道為什么用異常加入判斷 ?
此請(qǐng)參考官方文檔 20.2.11. 光標(biāo) 光標(biāo)
這把 MySQL 游標(biāo) 異常后 捕捉
并設(shè)置 循環(huán)使用 變量 tmpname 為 null 跳出循環(huán)。
- declare CONTINUE HANDLER FOR SQLSTATE '02000' SET tmpname = null;
開(kāi)游標(biāo)
OPEN cur1;
游標(biāo)向下走一步
- FETCH cur1 INTO tmpName;
循環(huán)體 這很明顯 把MySQL 游標(biāo)查詢出的 name 都加起并用 ; 號(hào)隔開(kāi)
- WHILE ( tmpname is not null) DO
- set tmpName = CONCAT(tmpName ,";") ;
- set allName = CONCAT(allName ,tmpName) ;
游標(biāo)向下走一步
- FETCH cur1 INTO tmpName;
- END WHILE;
- CLOSE cur1;
- select allName ;
- END;//
- call useCursor()//
運(yùn)行結(jié)果:
代碼
- MySQL> call useCursor()//
- +--------------------------------------+
- | allName |
- +--------------------------------------+
- | f1;c3;c6;c5;c2;c4;c1;f1;f3;f4;f2;f5; |
- +--------------------------------------+
- 1 row in set (0.00 sec)
代碼
- DELIMITER $$
- DROP PROCEDURE IF EXITS cursor_example$$
- CREATE PROCEDURE cursor_example()
- READS SQL DATA
- BEGIN
- DECLARE l_employee_id INT;
- DECLARE l_salary NUMERIC(8,2);
- DECLARE l_department_id INT;
- DECLARE done INT DEFAULT 0;
- DECLARE cur1 CURSOR FOR SELECT employee_id, salary, department_id FROM employees;
- DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
- OPEN cur1;
- emp_loop: LOOP
- FETCH cur1 INTO l_employee_id, l_salary, l_department_id;
- IF done=1 THEN
- LEAVE emp_loop;
- END IF;
- END LOOP emp_loop;
- CLOSE cur1;
- END$$
- DELIMITER ;
代碼
創(chuàng)建過(guò)程
- DELIMITER //
- DROP PROCEDURE IF EXISTS test //
- CREATE PROCEDURE test()
- BEGIN
- DECLARE done INT DEFAULT 0;
- DECLARE a VARCHAR(200) DEFAULT '';
- DECLARE c VARCHAR(200) DEFAULT '';
- DECLARE mycursor CURSOR FOR SELECT fusername FROM uchome_friend;
- DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
- OPEN mycursor;
- REPEAT
- FETCH mycursor INTO a;
- IF NOT done THEN
- SET c=CONCAT(c,a);
字符串相加
- END IF;
- UNTIL done END REPEAT;
- CLOSE mycursor;
- SELECT c;
- END //
- DELIMITER ;
以上的相關(guān)內(nèi)容就是對(duì)MySQL 游標(biāo)使用的介紹,望你能有所收獲。
【編輯推薦】
- linux MySQL 命令的正確應(yīng)用
- MySQL命令行導(dǎo)出相關(guān)數(shù)據(jù)庫(kù)實(shí)操
- 實(shí)現(xiàn)MySQL備份和還原在Win32下
- MySQL命令行導(dǎo)出相關(guān)數(shù)據(jù)庫(kù)實(shí)操
- 實(shí)現(xiàn)MySQL備份和還原在Win32下