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

吾爱主题 阅读:136 2024-04-05 14:22:42 评论:0

Mysql存储过程

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

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

解析:

  • IN 代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,........)
  • OUT 代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)
  • INOUT 代表既可以传入也可以返回 ,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)

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

A.定义变量语法:

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

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

B.变量赋值:

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

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

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

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

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

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

c.逻辑判断:

?
1 2 3 4 5 6 7 8 9 10 11 12 13 #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)循环:

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 #例.单游标循环: 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 ; -- 结束存储过程
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 #例.多游标循环: 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.存储过程的调用

?
1 2 3 4 5 6 #调用没有返回值的存储过程CALL 存储过程名(参数.....);   #调用有返回值的存储过程(获得返回值)   CALL 存储过程名(@aaa); SELECT @aaa;

4.删除存储过程

?
1 DROP PROCEDURE 存储过程名;

5.注意事项

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

原文链接:https://www.cnblogs.com/Moming0/p/11428960.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容