zoukankan      html  css  js  c++  java
  • MYSQL存储过程即常用逻辑

    Mysql存储过程

    1.创建存储过程语法(格式)

    DELIMITER $
    CREATE PROCEDURE 存储过程名A(IN 传入参数名a INTIN 传入参数名b VARCHAR(20),OUT 返回参数名c INTBEGIN
      内容..........
    END $

    解析:

        IN 代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,........)

        OUT 代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)

        INOUT 代表既可以传入也可以返回 ,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)

    2.存储过程内具体语法与逻辑

      A.定义变量语法:

              DECLARE 变量名a 参数类型(INT,VARCHAR(20),BOOLEAN,........) [DEFAULT NULL];

              注:可以在参数类型后面加  DEFAULT NULL; 来设置初始值。

      B.变量赋值:

            方式1(直接对变量进行赋值):

                SET 定义的变量a = NEW();

            方式2(sql查询的结果直接赋值给变量):

                SELECT `student`.age INTO 定义的变量a FROM `student` WHERE...........

            方式3(sql查询的结果直接赋值给多个变量):

                SELECT `student`.name AS 定义的变量a,`student`.age AS 定义的变量b INTO 定义的变量a,定义的变量b FROM `student` ...............

      c.逻辑判断:

      #IF判断:    
    
          IF 条件语句(3>5) THEN
                 条件为TRUE时执行.........;
          END IF
      #
    IF ELSE判断:
          
    IF 条件(a>0) THEN    条件为(a>0)时执行........;       ELSE IF 条件(a<0) THEN          条件为(a<0)时执行.......;       ELSE          其它执行.......;       END IF;

      D.游标,(LOOP)循环:

    #例.单游标循环:
    DELIMIETER $
    create
    procedure my_procedure() -- 创建存储过程 begin -- 开始存储过程 declare my_id varchar(32); -- 自定义变量1 declare my_name varchar(50); -- 自定义变量2 DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false DECLARE cur CURSOR FOR ( SELECT id, name FROM t_people ); -- 定义游标并输入结果集 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 绑定控制变量到游标,游标循环结束自动转true OPEN cur; -- 打开游标 posLoop: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到 FETCH cur into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12    IF done THEN -- 判断是否继续循环      LEAVE posLoop; -- 结束循环    END IF; -- 自己要做的事情,在 sql 中直接使用自定义变量即可 UPDATE t_user SET c_name = my_name WHERE id = my_id and rtrim(ltrim(c_name)) = ''; -- 左右去空格 COMMIT; -- 提交事务 END LOOP posLoop; -- 结束自定义循环体 CLOSE cur; -- 关闭游标 END $ -- 结束存储过程  
    #例.多游标循环:
    DELIMITER $
    create procedure my_procedure() -- 创建存储过程
    BEGIN -- 开始存储过程
      declare my_id varchar(32); -- 自定义变量1   declare my_name varchar(50); -- 自定义变量2   DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false   DECLARE cur_1 CURSOR FOR ( SELECT id, name FROM t_people ); -- 定义游标并输入结果集   DECLARE cur_2 CURSOR FORSELECT id_2,name_2 FROM t_people_2); --定义游标并输入结果集   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 绑定控制变量到游标,游标循环结束自动转true   OPEN cur_1; -- 打开游标    posLoop: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到    FETCH cur_1 into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12       IF done THEN -- 判断是否继续循环         LEAVE posLoop; -- 结束循环      END IF;    -- 自己要做的事情,在 sql 中直接使用自定义变量即可    UPDATE ..........;  --自己要做的具体操作    END LOOP posLoop; -- 结束自定义循环体    CLOSE cur_1; -- 关闭游标     SET done = FALSE;  -- 因为当第一个游标遍历完后其值被handler设置为TRUE了,如果不用set把它设置为 FALSE ,那么第二个游标就不会遍历了。(最好是在每个打开游标的操作前都用该语句,以确保游标能真正遍历)      OPEN cur_2; -- 打开游标    posLoop_2: LOOP -- 开始循环体,myLoop为自定义循环名,结束循环时用到    FETCH cur_2 into my_id, my_name; -- 将游标当前读取行的数据顺序赋予自定义变量12       IF done THEN -- 判断是否继续循环         LEAVE posLoop_2; -- 结束循环      END IF;    -- 自己要做的事情,在 sql 中直接使用自定义变量即可    INSERT ..........;   --自己要做的具体操作    END LOOP posLoop_2; -- 结束自定义循环体    CLOSE cur_2; -- 关闭游标     
    END; -- 结束存储过程

    3.存储过程的调用

    #调用没有返回值的存储过程

    CALL 存储过程名(参数.....); #调用有返回值的存储过程(获得返回值) CALL 存储过程名(
    @aaa); SELECT @aaa;

    4.删除存储过程

    DROP PROCEDURE 存储过程名;   

    5.注意事项

      存储过程中的分号(;)很重要,不能省略。

  • 相关阅读:
    算法导论9.33
    第6章 堆排序
    算法导论9.36算法导论9.36 .
    算法导论83排序不同长度的数据项
    算法导论76对区间的模糊排序
    第8章 线性时间排序
    在bochs上运行的第一个操作系统
    算法导论6.58堆排序K路合并
    js中的preventDefault与stopPropagation详解(转)
    JS基础RegExp
  • 原文地址:https://www.cnblogs.com/Moming0/p/11428960.html
Copyright © 2011-2022 走看看