服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|

服务器之家 - 数据库 - Mysql - MYSQL存储过程即常用逻辑知识点总结

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

2020-12-02 16:08MoMing Mysql

在本篇文章里小编给大家整理的是关于MYSQL存储过程即常用逻辑知识点,有需要的朋友们可以学习下。

Mysql存储过程

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

?
1
2
3
4
5
DELIMITER $
CREATE PROCEDURE 存储过程名A(IN 传入参数名a INTIN 传入参数名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

延伸 · 阅读

精彩推荐
  • Mysqlmytop 使用介绍 mysql实时监控工具

    mytop 使用介绍 mysql实时监控工具

    mytop 是一个类似 Linux 下的 top 命令风格的 MySQL 监控工具,可以监控当前的连接用户和正在执行的命令 ...

    朱茂海3002019-12-02
  • Mysql简单实现SQLServer转MYSQL的方法

    简单实现SQLServer转MYSQL的方法

    SqlServer数据转换成mysql数据,可以说是一个老生常谈了,网上也有很多的方法,今天我们来看一种不一样的方法,而且也非常的简单,虽然有点小缺陷,但...

    MYSQL教程网2712020-04-18
  • MysqlMySQL数据库安全设置与注意事项小结

    MySQL数据库安全设置与注意事项小结

    现在很多朋友使用mysql数据库,为了安全考虑我们就需要考虑到mysql的安全问题,例如需要将mysql以普通用户权限运行,就算出问题了有了root也不能控制系统...

    MYSQL教程网4292020-01-08
  • Mysqlmysql 8.0.11 安装配置方法图文教程(win10)

    mysql 8.0.11 安装配置方法图文教程(win10)

    这篇文章主要为大家详细介绍了mysql 8.0.11 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    静看丶雨落时2102020-09-17
  • Mysqlmysql Myisamchk小工具使用手册

    mysql Myisamchk小工具使用手册

    Myisamchk是MyISAM表维护的一个非常实用的工具。可以使用myisamchk实用程序来获得有关数据库表的信息或检查、修复、优化他们。myisamchk适用MyISAM表(对应.MYI和...

    mysql教程网4082019-10-24
  • Mysql解决Mysql服务器启动时报错问题的方法

    解决Mysql服务器启动时报错问题的方法

    这篇文章主要介绍了解决Mysql服务器启动时报错问题的方法,需要的朋友可以参考下 ...

    pursuer.chen4702020-05-21
  • Mysqlmysql错误处理之ERROR 1665 (HY000)

    mysql错误处理之ERROR 1665 (HY000)

    最近一直在mysql的各个版本直接徘徊,这中间遇到了各种各样的错误,将已经处理完毕的几个错误整理了一下,分享给大家,这次我们来看看错误提示 ERR...

    hebedich5122020-04-08
  • MysqlMySQl数据库必知必会sql语句(加强版)

    MySQl数据库必知必会sql语句(加强版)

    本文给大家分享了一篇关于mysql数据库必会sql语句加强版内容,非常不错,具有参考借鉴价值,需要的朋友参考下吧...

    mysql教程网4022020-07-25