MYSQL 遊標的使用
阿新 • • 發佈:2017-06-28
open one not 插入 log proc val set not found
CREATE PROCEDURE `test`.`new_procedure` () BEGIN -- 需要定義接收遊標數據的變量 DECLARE a CHAR(16); -- 遊標 DECLARE cur CURSOR FOR SELECT i FROM test.t; -- 遍歷數據結束標誌 DECLARE done INT DEFAULT FALSE; -- 將結束標誌綁定到遊標 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 打開遊標 OPEN cur; -- 開始循環 read_loop: LOOP -- 提取遊標裏的數據,這裏只有一個,多個的話也一樣; FETCH cur INTO a; -- 聲明結束的時候 IF done THEN LEAVE read_loop; END IF; -- 這裏做你想做的循環的事件 INSERT INTO test.t VALUES (a); END LOOP; -- 關閉遊標 CLOSE cur; END
這裏有一個比較坑的地方,註意,變量的定義不要和你的select的列的鍵同名!不然,fetch into 會失敗!
另外 :
如果沒有則插入數據,如果有則更新的方法:
insert into `test` values (a,b) ON DUPLICATE KEY UPDATE `a`=c;
MYSQL 遊標的使用