mysql游标的使用

原创 2011年01月18日 16:01:00

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

但是其中有几点需要注意,就是为什么要加入 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()
//

MySql中DECLARE CONTINUE HANDLER FOR NOT FOUND 解释

转载地址:http://blog.csdn.net/tengdazhang770960436/article/details/12712143 1.解释: 在MySQL的存储过程中经常...
  • wanglha
  • wanglha
  • 2016年05月17日 10:28
  • 5071

DECLARE CONTINUE HANDLER FOR NOT FOUND 解释

1.解释: 在mysql的存储过程中经常会看到这句话:DECLARE CONTINUE HANDLER FOR NOT FOUND。 它的含义是:若没有数据返回,程序继续,并将变量IS_FOUND...
  • tengdazhang770960436
  • tengdazhang770960436
  • 2013年10月14日 17:47
  • 21271

mysql游标实现时当内部查询有一次未查询到结果时就自动退出循环解决办法

DECLARE done INT DEFAULT 0;    DECLARE cur2 cursor for SELECT  periodid,name,periodtype  from  ed...
  • builderwfy
  • builderwfy
  • 2016年12月24日 14:19
  • 251

Mysql 异常处理--condition和handler

定义条件和处理条件的定义和处理可以用来定义在处理过程中遇到问题时相应的处理步骤。1.条件的定义 DECLARE condition_name CONDITION FOR condition_val...
  • ashic
  • ashic
  • 2016年08月05日 10:52
  • 1490

DECLARE CONTINUE HANDLER FOR NOT FOUND 解释

1.解释: 在MySQL的存储过程中经常会看到这句话:DECLARE CONTINUE HANDLER FOR NOT FOUND。 它的含义是:若没有数据返回,程序继续,并将变量IS_FOUND...
  • qq_16504067
  • qq_16504067
  • 2016年12月22日 09:33
  • 743

mysql存储过程的注意点

以下为我写的一个例子:主要功能是把OA的弹窗提醒功能与redmine连接在一起; delimiter // create trigger t_trigger AFTER insert on iss...
  • wesleyluo
  • wesleyluo
  • 2013年02月20日 17:44
  • 4377

MYSQL游标(CURSOR)关于NOT FOUND或02000结束状态只遍历一次的问题

经常在定义cursor的时候都会定义cursor未找到(NOT FOUND或SQLSTATE '02000')的条件来标识游标结束。 完整的存储过程如下: CREATE PROCEDURE PR_...
  • u011214505
  • u011214505
  • 2016年11月25日 16:23
  • 1865

oracle 10g不支持 continue解决方法

解决方案如下 :采用goto进行跳转DECLARE done BOOLEAN; BEGIN FOR i IN 1..50 LOOP IF done THEN ...
  • topwqp
  • topwqp
  • 2015年07月31日 14:35
  • 4708

MySql错误处理-错误处理的例子

有几种错误处理的声明形式:  § 如果任何错误(不是 NOT FOUND ) , 设置 l_error 为 1 后继续执行:  DECLARE CONTINUE HANDLER FOR SQLEXCE...
  • zhanglu0223
  • zhanglu0223
  • 2015年08月16日 13:48
  • 2722

mysql存储过程的注意点

以下为我写的一个例子:主要功能是把OA的弹窗提醒功能与redmine连接在一起; delimiter // create trigger t_trigger AFTER insert on iss...
  • wesleyluo
  • wesleyluo
  • 2013年02月20日 17:44
  • 4377
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mysql游标的使用
举报原因:
原因补充:

(最多只允许输入30个字)