DECLARE CONTINUE HANDLER FOR NOT FOUND


1、解釋:

在mysql的存儲過程中經常會看到這句話:DECLARE CONTINUE HANDLER FOR NOT FOUND。

它的含義是:若沒有數據返回,程序繼續,並將變量IS_FOUND設為0 ,這種情況是出現在select XX into XXX from tablename的時候發生的。

2、每個游標必須使用不同的declare continue handler for not found set done=1來控制游標的結束。

3、示例:

/*建立存儲過*/
CREATE PROCEDURE useCursor()
BEGIN
/*局部變量的定義*/ 
declare tmpName varchar(20) default '' ;
declare allName varchar(255) default '' ;

declare cur1 CURSOR FOR SELECT name FROM test.level ;

declare CONTINUE HANDLER FOR SQLSTATE '02000' SET tmpname = null;
#也可以這么寫

#DECLARE CONTINUE HANDLER FOR NOT FOUND SET tmpname = null;

OPEN cur1;


FETCH cur1 INTO tmpName;
    WHILE ( tmpname is not null) DO
    set tmpName = CONCAT(tmpName ,";") ;
    set allName = CONCAT(allName ,tmpName) ;
    FETCH cur1 INTO tmpName;
END WHILE;


CLOSE cur1;

select allName ;
END;
call useCursor()

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM