大鹏一日同风起,扶摇直上九万里。这篇文章主要讲述MySQL数据库(31):存储过程 procedure相关的知识,希望能为你提供帮助。
存储过程 procedurestored procedure 完成特定功能的SQL语句集,存储在数据库中,经过第一次编译之后再次调用不需要编译(效率较高)
1、存储过程与函数的区别
1.1、相同点
- 都是为了可重复地执行操作数据库的SQL语句集合
- 都是一次编译,多次执行
- 标识符不同,函数function 过程 procedure
- 函数中有返回值,且必须返回,而过程没有返回值
- 过程无返回值类型,不能将结果直接赋值给变量;函数有返回值类型,调用时,除了在select中,必须将返回值赋值给变量
- 函数可以再select语句中直接使用,而过程不能
基本语法
create procedure 过程名字([参数列表])
bengin
过程体
end
结束符
如果只有只有一条指令可以省略begin和end
create procedure my_pro1()
select * from my_student;
过程基本上可以完成函数对应的所有功能
-- 修改语句结束符
delimiter $$
-- 创建过程
create procedure my_pro2()
begin
-- 求1到100之间的和-- 创建局部变量
declare i int default 1;
-- declare sum int default 0;
-- 会话变量
set @sum = 0;
-- 开始循环获取结果
while i <
= 100 do
-- 求和
set @sum = @sum + i;
set i = i + 1;
end while;
-- 显示结果
select @sum;
end
$$
delimiter ;
2.2、查看过程
-- 查看所有存储过程
show procedure status [like pattern];
-- 查看过程的创建语句
show create procedure 过程名字\\G
2.3、调用过程
过程没有返回值
基本语法
call 过程名([实参列表]);
-- eg:
call my_pro2();
+------+
| @sum |
+------+
| 5050 |
+------+
2.4、删除过程
基本语法
drop procedure 过程名;
3、存储过程的形参类型存储过程的参数和函数一样,需要制定其类型
但是存储过程对参数还有额外的要求,自己的参数分类
- in:(值传递)参数从外部传入,在过程内部使用,可以是直接数据,也可以是保存数据的变量
- out:(引用传递)参数在过程中赋值,传入必须是变量,如果有外部数据,会被清空为null
- inout:(引用传递)数据可以从外部传入过程内部使用,同时内部操作之后,又回将数据返回给外部
-- 创建3个会话变量
set @var1 = 1;
set @var2 = 2;
set @var3 = 3;
-- 查询会话变量
select @var1, @var2, @var3;
+-------+-------+-------+
| @var1 | @var2 | @var3 |
+-------+-------+-------+
|1 |2 |3 |
+-------+-------+-------+
1 row in set (0.00 sec)-- 修改语句结束符
delimiter $$-- 定义过程
create procedure my_pro3(in a int, out b int, inout c int)
begin
-- 查看传入的3个数据值
select a, b, c;
-- +------+------+------+
-- | a| b| c|
-- +------+------+------+
-- |1 | NULL |3 |
-- +------+------+------+-- 修改3个变量值
set a = 10;
set b = 20;
set c = 30;
select a, b, c;
-- +------+------+------+
-- | a| b| c|
-- +------+------+------+
-- |10 |20 |30 |
-- +------+------+------+-- 查看会话变量
select @var1, @var2, @var3;
-- +-------+-------+-------+
-- | @var1 | @var2 | @var3 |
-- +-------+-------+-------+
-- |1 |2 |3 |
-- +-------+-------+-------+-- 修改会话变量
set @var1 = a;
set @var2 = b;
set @var3 = c;
select @var1, @var2, @var3;
-- +-------+-------+-------+
-- | @var1 | @var2 | @var3 |
-- +-------+-------+-------+
-- | a| b| c|
-- +-------+-------+-------+
end
$$delimiter ;
-- 调用过程
call my_pro3(@var1, @var2, @var3);
-- 再次查看会话变量
mysql>
select @var1, @var2, @var3;
+-------+-------+-------+
| @var1 | @var2 | @var3 |
+-------+-------+-------+
| a|20 |30 |
+-------+-------+-------+
分析:
1、实参传入过程之后,实际上没有改变外部变量的值,而是把值给了形参,out类型不能接收外部变量的值,默认为null
【MySQL数据库(31)(存储过程 procedure)】2、当过程执行到end 的时候,如果是out或inout变量,会将形参的值重新赋值给实参变量
推荐阅读
- 2022 年你手机里有哪些堪称神器的 App()
- 「Node学习笔记」Node.js的模块实现及编译
- 专栏开篇(我为什么要写这篇专栏())
- 全志D1-H Dock ProYoC RTOS 实战(HaaS UI UED桌面显示)
- C语言教程 - 制作单位转换器
- SpringBoot2.x整合Prometheus+Grafana附源码
- 超大规模数据中心内的数据链路层自动测试案例
- 多线程原理和常用方法以及Thread和Runnable的区别
- 数据库数据恢复磁盘空间不足导致sql server故障的数据恢复案例