MySQL知识点复习 - 存储过程

存储过程

通过 CREATE PROCEDURE 实现的语句集,有输入输出参数,可以声明变量,有控制语句(if/else/case/while等等)。

优点:梭哈,性能高,看上去跟触发器的意思差不多,触发器只是需要触发条件。

应用场景:性能要求高,业务复杂,那些只需要在数据库层面的操作可以写在这里。

缺点:不同数据库的语法都不同,迁移难度++,要是哪天有迁移需求得重写,写太多还混乱。

所以现在有些求职的信息说需要丰富的写存储过程的经验,我看着都有点害怕,里面不是一坨存储过程吧?

基本语法

存储过程没有返回值,不可以放在其他语句中一起用

IN:可以传参到过程中(输入)

OUT:执行完后返回的结果(输出)

INOUT:可以输入也可以输出

创建一个存储过程

sql 复制代码
CREATE PROCEDURE test() -- 这个是存储存储过程的名称
BEGIN  -- 开始

	# 这里就写sql集

end; -- 结束

调用存储过程

重点就是这个call

以前试过直接在mybatis的xml里面直接写一个call也能用,主管给我写好的存储过程,真香哈哈哈

sql 复制代码
CALL TEST(); 

查看创建的存储过程

sql 复制代码
 show PROCEDURE STATUS 
 [where name = 'test'] -- 可以帅选一下

带参数的存储过程

in 输入参数

  1. 可以声明一个值:
sql 复制代码
set test_in = 1;
  1. 创建带参数的存储过程
sql 复制代码
CREATE PROCEDURE test(in test_param_in int)
begin
	xxx
end;
  1. 调用
sql 复制代码
call test(@test_in); 
看到菜鸟教程里面有例子挺好的,贴过来学习一下,原文地址:https://www.runoob.com/w3cnote/mysql-stored-procedure.html
sql 复制代码
mysql> delimiter $$ -- 这个意思是分号的意思,然后加上$$的意思就是 分号的分号的意思,反正意思就是分割上面的写法,然后再结束
mysql> create procedure in_param(in p_in int)
    -> begin
    ->   select p_in;
    ->   set p_in=2;
    ->    select P_in;
    -> end$$
mysql> delimiter ;
 
mysql> set @p_in=1;
 
mysql> call in_param(@p_in);
+------+
| p_in |
+------+
|    1 |
+------+
 
+------+
| P_in |
+------+
|    2 |
+------+
 
mysql> select @p_in; -- 全局变量的值不会被影响
+-------+
| @p_in |
+-------+
|     1 |
+-------+

out 输出参数

out简单的理解就是"返回值"的意思

sql 复制代码
mysql> delimiter
mysql> create procedure out_param(out p_out int)
    ->   begin
    ->     select p_out; -- 输出,不会被传参,因为这个是out,所以下面是个NULL
    ->     set p_out=2; -- 设值,所以下面会输出2
    ->     select p_out;
    ->   end
mysql> delimiter ;
 
mysql> set @p_out=1;
 
mysql> call out_param(@p_out);
+-------+
| p_out |
+-------+
|  NULL |
+-------+

+-------+
| p_out |
+-------+
|     2 |
+-------+
 
mysql> select @p_out;
+--------+
| @p_out |
+--------+
|      2 |
+--------+
# 调用了out_param存储过程,输出参数,改变了p_out变量的值

inout输入参数

sql 复制代码
mysql> delimiter $$
mysql> create procedure inout_param(inout p_inout int)
    ->   begin
    ->     select p_inout; -- 下面传入了参数,所以会输出1
    ->     set p_inout=2; -- 改变这个值
    ->     select p_inout; -- 输出2
    ->   end
    -> $$
mysql> delimiter ;
 
mysql> set @p_inout=1;
 
mysql> call inout_param(@p_inout);
+---------+
| p_inout |
+---------+
|       1 |
+---------+
 
+---------+
| p_inout |
+---------+
|       2 |
+---------+
 
mysql> select @p_inout;
+----------+
| @p_inout |
+----------+
|        2 |
+----------+
# 调用了inout_param存储过程,接受了输入的参数,也输出参数,改变了变量
相关推荐
羊锦磊5 分钟前
[ Redis ] SpringBoot集成使用Redis(补充)
java·数据库·spring boot·redis·spring·缓存·json
倔强的石头_32 分钟前
【金仓数据库】ksql 指南(三) —— 创建与管理表空间和模式
数据库
冷崖1 小时前
MySQL-TrinityCore异步连接池的学习(七)
学习·mysql
程序新视界2 小时前
详解MySQL两种存储引擎MyISAM和InnoDB的优缺点
数据库·后端·mysql
半路_出家ren2 小时前
设计一个学生管理系统的数据库
linux·数据库·sql·mysql·网络安全·数据库管理员
金仓拾光集4 小时前
筑牢风控生命线:金仓数据库替代MongoDB,重构证券融资融券业务的数据基石
数据库·mongodb·信创·1024程序员节·kingbasees·国产化替代
枫叶梨花4 小时前
实战:将 Nginx 日志实时解析并写入 MySQL,不再依赖 ELK
mysql·nginx·elk
那我掉的头发算什么4 小时前
【数据库】navicat的下载以及数据库约束
android·数据库·数据仓库·sql·mysql·数据库开发·数据库架构
纪伊路上盛名在4 小时前
如何批量获取蛋白质序列的所有结构域(domain)数据-2
数据库·人工智能·机器学习·统计·计算生物学·蛋白质
tuokuac5 小时前
虚拟机挂起,重启后主机连接不上虚拟机docker中的mysql?(docker网络状态假死)
网络·mysql·docker