【MySQL】存储过程

🐼什么是存储过程

下来看看存储过程的定义:存储过程是⼀组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字和参数来执行,并获取相应的结果。我们发现存储过程跟函数的定义特别相似,是的,我们可以把存储过程理解为一组完成特定功能的数据库的函数。

🐼存储过程的作用

如果没有存储过程,那么我们的请求直接打向数据库中的表;有了存储过程,我们的请求是向存储过程发起的,存储过程又是一组编译好的数据库集,操作起来就很快了。

存储过程我们可以想象函数的作用:

其优点:

1.很好的封装性,把业务逻辑封装到数据库内部,减少了程序的复杂性

2.增加了存储过程这一层软件层,很好的保护了数据库

3.性能优化:存储过程在创建时编译并存储在数据库中,执行速度比单个SQL语句快。

4.代码重用:存储过程可以复用,减少重复代码,提高代码的可维护性。

缺点:

可移植性差:存储过程不能跨数据库移植,更换数据库时需要重新编写。

调试困难:只有少数数据库管理系统⽀持存储过程的调试,开发和维护困难。

不适合高并发场景:在高并发场景下,存储过程可能会增加数据库的压力,难以维护


🐼存储过程的创建/查看/删除

存储过程是procedure关键字,它的创建也是create关键字。

创建一个存储过程的标准过程是(最佳实践):

sql 复制代码
-- 修改SQL语句结束标识符为 //
DELIMITER //
-- 创建存储过程
CREATE PROCEDURE 存储过程名 (参数列表)
BEGIN
-- SQL 语句
END //
-- 修改SQL语句结束标识符为 ;
DELIMITER ;

其中delimiter // 是定义结束标识符。比如如果这样一段代码放在cmd命令上就会有语法错误,因为编译器不知道你的结束标志,这导致了你在写sql语句的过程中就结束了,执行不到END。

sql 复制代码
create procedure p_cal_Sum()
BEGIN
  -- 多条sql语句来实现一组特定功能
  select name,chinese+math+english as total from exam; -- 走到这里就结束了
END;
 -- 调用
CALL p_cal_Sum();

所以在命令行中创建存储过程要先修改SQL语句结束标识符,比如 DELIMITER //,最后不要忘记,在定义回来 delimiter ;所以一定使用delimiter去定义结束符。

所以在生产环境或者业务环境,一定要在开头写DELIMITER //,结尾写DELIMITER ;

调用存储过程使用:

sql 复制代码
-- 调⽤存储过程
CALL 存储过程名 (参数列表);

存储过程本质就是编译好的一组sql集嘛,也要占磁盘空间的,查看存储过程是:

sql 复制代码
-- 查看指定数据库中创建的存储过程
SELECT * FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = '数据库名';
-- 查看存储过程的定义
SHOW CREATE PROCEDURE 存储过程名;

删除存储过程是:

sql 复制代码
DROP PROCEDURE [IF EXISTS] 存储过程名;

如果把上面的操作都写在一起:

sql 复制代码
-- 创建一个存储过程
use topic01;
-- 先修改结束标识符
delimiter //
create procedure p_cal_Sum()
BEGIN
  -- 多条sql语句来实现一组特定功能
  select name,chinese+math+english as total from exam;
END // 
-- 不要忘记修改回来
delimiter ;
 -- 调用存储过程
CALL p_cal_Sum();

drop procedure if exists p_cal_Sum;
相关推荐
风向决定发型丶4 小时前
redis集群搭建
数据库·redis·缓存
wei_shuo6 小时前
KES 扩展与插件开发实战:自定义函数、触发器与第三方插件集成
数据库·kes
风中芦苇啊7 小时前
从直接生成到受控配置:新一代图表Agent的SQL安全生成范式
数据库·sql·安全
吴声子夜歌7 小时前
SQL进阶——窗口函数
数据库·sql
周杰伦的稻香7 小时前
MySQL8.0+中引入的SET_USER_ID权限迭代SUPER权限指定 DEFINER
数据库·mysql
动恰客流统计7 小时前
客流统计如何结合AI分析?从传统计数到智能决策的技术升级路径
数据库·人工智能·边缘计算
宠友信息8 小时前
多端数据互通场景下Spring Boot仿小红书源码结构设计
数据库·spring boot·redis·缓存·架构
风曦Kisaki8 小时前
#Linux数据库管理Day06:主从同步与MaxScale读写分离
linux·运维·数据库
影寂ldy8 小时前
C# try-catch 异常处理全套笔记
服务器·数据库·c#
长不胖的路人甲8 小时前
Redis 缓存的数据持久化方案讲解
数据库·redis·缓存