• 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

  • 相关阅读:
    【goframe】ORM驱动开发
    “大将辈出”培训笔记
    axios在vue中的使用
    python 获取全年日期及日期详情
    微信小程序获取手机号授权完整实现
    Mac升级node.js
    【Oracle】Oracle开启和关闭闪回
    【Oracle】将RAC闪回到指定的闪回点
    【Oracle】Oracle 12C Far Sync
    【Docker】docker镜像下载到本地并在其他机器恢复
  • 原文地址:https://www.cnblogs.com/liushui-sky/p/8818057.html
Copyright © 2020-2023  润新知