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

 更新时间:2019年08月29日 15:54:35   作者:MoMing  
在本篇文章里小编给大家整理的是关于MYSQL存储过程即常用逻辑知识点,有需要的朋友们可以学习下。

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.注意事项

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

相关文章

  • MySQL中Set与Enum的区别和使用详解

    MySQL中Set与Enum的区别和使用详解

    这篇文章主要介绍了MySQL中Set与Enum的区别和使用详解,数据库中的 set 是一种集合数据类型,用于存储不同的元素,每个元素只能出现一次,Set 的主要作用是方便进行集合运算,如并集、交集等操作,需要的朋友可以参考下
    2024-01-01
  • Ubuntu 20.04 安装和配置MySql5.7的详细教程

    Ubuntu 20.04 安装和配置MySql5.7的详细教程

    这篇文章主要介绍了Ubuntu 20.04 安装和配置MySql5.7的相关资料,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Mysql巧用join优化sql的方法详解

    Mysql巧用join优化sql的方法详解

    这篇文章主要给大家介绍了关于Mysql巧用join优化sql的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • 初探SQL语句复合主键与联合主键

    初探SQL语句复合主键与联合主键

    这篇文章主要介绍了初探SQL语句复合主键与联合主键的相关内容,具有一定参考价值,这里给大家分享下,需要的朋友可以参考。
    2017-10-10
  • Mysql存储引擎详解

    Mysql存储引擎详解

    存储引擎其实就是如何实现存储数据,如何为存储的数据建立索引以及如何更新,查询数据等技术实现的方法。本文我们来详细探讨下MySQL中的几个存储引擎(MyISAM、InnoDB、archive、MERGE)的相关知识
    2016-12-12
  • Mysql计算n日留存率的实现

    Mysql计算n日留存率的实现

    本文主要介绍了Mysql计算n日留存率的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • MySql 设置表格字段key中的值

    MySql 设置表格字段key中的值

    本文主要介绍了MySql 设置表格字段key中的值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-05-05
  • MySQL 配置文件my.cnf 例子最详细翻译

    MySQL 配置文件my.cnf 例子最详细翻译

    MySQL 配置文件my.cnf 例子最详细翻译,需要的朋友可以看看。
    2009-05-05
  • 一条SQL更新语句的执行过程解析

    一条SQL更新语句的执行过程解析

    这篇文章主要介绍了一条SQL更新语句的执行过程解析,所以一条更新语句的执行流程又是怎样的呢?下面我们一起进入文章了解更多具体内容吧
    2022-05-05
  • mysql仿asp的数据库操作类

    mysql仿asp的数据库操作类

    使用说明: 该类完全按照ADO的习惯书写的,用过ASP的人都觉得ASP连接数据库比PHP好用(这是我的感觉), 但PHP得一个一个API地写,挺累,该类做了完全的封装 创建类的实例时可以指定一个数据库表和选择的数据库,如:new MySQLDB("table","database");
    2008-04-04

最新评论