zoukankan      html  css  js  c++  java
  • 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()
    

      

  • 相关阅读:
    PS转换图片——我教你
    通过Ajax——异步获取相关问题解答
    Spring的线程安全
    Spring MVC的工作机制
    Annotation的语法和使用
    Spring Bean的生命周期
    浅谈Spring
    Spring的事务管理
    行为型模式
    结构型模式
  • 原文地址:https://www.cnblogs.com/lp-zy/p/4377289.html
Copyright © 2011-2022 走看看