zoukankan      html  css  js  c++  java
  • 存储过程

    存储过程中可以用int 的1代表true,来做判断条件

    /*mysqll过程*/

    CREATE PROCEDURE `NewProcedure`(`Param` int(11))
    BEGIN
    DECLARE b INT default 0;
    declare var_id,var_value varchar(20) default null;
    DECLARE cur1 cursor
    FOR
    select testId from test2 ;

    declare continue handler for not found set b=1;
    open cur1;

    repeat
    fetch cur1 into var_id;

    /*本身repeat util是do while的形式,会多执行一次,加上if not b then判断解决多循环一次的问题*/

    /*把do while形式的循环改成while*/

    if not b then
    select var_id;
       set var_value = concat('testName:',var_id);

    /*insert into test values(var_id,var_value);*/
    end if;
    until b=1
    end repeat;

    close cur1;

    END;

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

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

  • 相关阅读:
    通知:逆天异常库 V1.0版本支持下载了~~
    【源码】Word转PDF V1.0.1 小软件,供新手参考
    GitHub实战系列汇总篇
    GitHub实战系列~4.把github里面的库克隆到指定目录+日常使用 2015-12-11
    GitHub实战系列~3.提交github的时候过滤某些文件 2015-12-10
    Windows无法安装到这个磁盘。请确保在计算机的BIOS菜单中启用了磁盘控制器
    GitHub实战系列~2.把本地项目提交到github中 2015-12-10
    Git异常:fatal: could not create work tree dir 'XXX': No such file or directory
    GitHub实战系列~1.环境部署+创建第一个文件 2015-12-9
    肉肉好走,愿你在异界依旧快乐活泼
  • 原文地址:https://www.cnblogs.com/longsanshi/p/7813268.html
Copyright © 2011-2022 走看看