mysql游标的使用

这是一个游标的使用例子.

但是其中有几点需要注意,就是为什么要加入 declare CONTINUE HANDLER FOR SQLSTATE '02000' SET tmpname = null;这样的一句话.

如果不加的话将直接报错.No data - zero rows fetched, selected, or processed 

另外也有人提示过这样的经验:

经验之谈: 
在MYSQL的存储过程一般要设个变量来跟踪是否NOT FOUND 

DECLARE IS_FOUND INTEGER DEFAULT 1; 
DECLARE CONTINUE HANDLER FOR NOT FOUND SET IS_FOUND=0; 
** 上面这行表示若没有数据返回,程序继续,并将变量IS_FOUND设为0 

这种情况是出现在select XX into XXX from tablename的时候发生的,这个时候如果XX是null就会有问题.其实也可以这样解决

select isnull(xxxx,0) into aaaa from tableName

这样如果遇到null就为0了..

/*初始化*/ 
drop procedure if exists   useCursor //    

/*建立 存储过程 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 不知道为什么用异常加入判断 ?
           *     此请参考官方文档 20.2.11. 光标 光标 
           *         这把 游标 异常后 捕捉 
           *         并设置 循环使用 变量 tmpname 为 null 跳出循环。
          */
         declare CONTINUE HANDLER FOR SQLSTATE '02000' SET tmpname = null;
    
    
    /*开游标*/ 
     OPEN cur1;
         /*游标向下走一步*/ 
         FETCH cur1 INTO tmpName;
         
         /* 循环体 这很明显 把游标查询出的 name 都加起并用 ; 号隔开 */
      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()//

转自:https://blog.csdn.net/yuri99/article/details/6150055

posted on 2018-04-13 09:17  苦涩的茶  阅读(281)  评论(0编辑  收藏  举报

// 1.生成目录索引列表