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

作者:MoMing 时间:2024-01-21 07:36:36 

Mysql存储过程

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


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.定义变量语法:


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)循环:


#例.单游标循环: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.注意事项

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

来源:https://www.cnblogs.com/Moming0/p/11428960.html

标签:MYSQL,存储过程,逻辑
0
投稿

猜你喜欢

  • 如何使用Python实现斐波那契数列

    2021-12-09 08:20:30
  • Python类属性的延迟计算

    2023-07-22 15:50:33
  • python 如何对logging日志封装

    2023-07-06 11:27:36
  • Python3导入CSV文件的实例(跟Python2有些许的不同)

    2023-09-21 05:19:29
  • 最简洁的SQL多重查询的解决方案

    2005-09-12 16:31:00
  • vue项目中全局引入1个.scss文件的问题解决

    2024-05-29 22:44:38
  • 十行代码使用Python写一个USB病毒

    2021-08-27 17:05:41
  • Pycharm在创建py文件时,自动添加文件头注释的实例

    2023-05-06 19:21:51
  • 使用Python编写一个简单的tic-tac-toe游戏的教程

    2021-01-26 04:27:43
  • 使用beaker让Facebook的Bottle框架支持session功能

    2023-07-01 02:35:35
  • 详解python-图像处理(映射变换)

    2023-12-23 06:43:35
  • js Event对象的5种坐标

    2024-04-22 22:31:32
  • Python 获取主机ip与hostname的方法

    2021-05-13 09:30:30
  • Django模板之基本的 for 循环 和 List内容的显示方式

    2021-09-24 05:18:24
  • MySQL 两种恢复数据的方法

    2024-01-18 03:48:35
  • 详解python连接telnet和ssh的两种方式

    2023-02-10 01:27:14
  • 用python实现前向分词最大匹配算法的示例代码

    2023-12-03 00:18:46
  • python对输出的奇数偶数排序实例代码

    2023-02-17 17:55:16
  • Mysql使用存储过程快速添加百万数据的示例代码

    2024-01-19 21:51:26
  • pandas去除重复列的实现方法

    2022-06-27 12:37:31
  • asp之家 网络编程 m.aspxhome.com