不灭的焱

加密类型:SHA/AES/RSA下载Go
复合类型:切片(slice)、映射(map)、指针(pointer)、函数(function)、通道(channel)、接口(interface)、数组(array)、结构体(struct) Go类型+零值nil
引用类型:切片(slice)、映射(map)、指针(pointer)、函数(function)、通道(channel) Go引用

作者:AlbertWen  添加时间:2020-07-30 23:45:57  修改时间:2025-11-29 23:06:14  分类:03.MySQL/PgSQL/Redis  编辑

在MySQL的存储过程中经常会看到这句话:DECLARE CONTINUE HANDLER FOR NOT FOUND

它的含义是:若没有数据返回,程序继续,并将变量 IS_FOUND 设为 0 ,这种情况是出现在类似:select XX into XXX from tablename 的时候发生的。

示例:

/* 建立存储过程 */
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()