• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MYSQL存储过程即常用逻辑知识点总结

    Mysql存储过程

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

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

    解析:

    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 条件(a0) THEN
             条件为(a0)时执行.......;
          ELSE
             其它执行.......;
          END IF;

    D.游标,(LOOP)循环:

    #例.单游标循环: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; -- 结束存储过程
    #例.多游标循环: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 FOR ( SELECT 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.注意事项

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

    您可能感兴趣的文章:
    • 深入了解Mysql逻辑架构
    • MySQL高级学习笔记(三):Mysql逻辑架构介绍、mysql存储引擎详解
    • 详解MySQL执行原理、逻辑分层、更改数据库处理引擎
    • Mysql逻辑架构详解
    • 关于避免MySQL替换逻辑SQL的坑爹操作详解
    • 利用PHP访问MySql数据库的逻辑操作以及增删改查的实例讲解
    • MySql存储过程之逻辑判断和条件控制
    • MySQL 利用frm文件和ibd文件恢复表数据
    • MySQL使用binlog日志做数据恢复的实现
    • MySQL 基于时间点的快速恢复方案
    • MySQL5.7 mysqldump备份与恢复的实现
    • MySQL 逻辑备份与恢复测试的相关总结
    上一篇:MySQL慢SQL语句常见诱因以及解决方法
    下一篇:mysql 错误号码1129 解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MYSQL存储过程即常用逻辑知识点总结 MYSQL,存储,过程,即,常用,