【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;
相关推荐
白太岁1 小时前
Redis:(6) 三级缓存+连接池与高性能 Redis 客户端封装
数据库·redis·缓存
山岚的运维笔记2 小时前
SQL Server笔记 -- 第78章:MS SQL Server 基本 DDL 操作
数据库·笔记·sql·microsoft·oracle·sqlserver
Albert Edison8 小时前
【Python】学生管理系统
开发语言·数据库·python
heimeiyingwang11 小时前
企业供应链 AI 优化:需求预测与智能调度
大数据·数据库·人工智能·机器学习
山岚的运维笔记12 小时前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
XLYcmy12 小时前
智能体大赛 目录
数据库·ai·llm·prompt·agent·检索·万方
盟接之桥12 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
闲人编程14 小时前
内存数据库性能调优
数据库·redis·字符串·高并发·哈希·内存碎片