【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;
相关推荐
wang2455981991 小时前
【MySQL基础篇】概述及SQL指令:DDL及DML
sql·mysql·oracle
2401_898075122 小时前
Python在金融科技(FinTech)中的应用
jvm·数据库·python
IvorySQL2 小时前
PostgreSQL 技术日报 (3月14日)|AI 落地 PostgreSQL 拒绝 PPT 空谈
数据库·postgresql·开源
JavaGuide2 小时前
鹅厂面试:SELECT * 一定导致索引失效?常见索引失效场景有哪些?
java·数据库·后端·mysql·大厂面试
wmfglpz882 小时前
NumPy入门:高性能科学计算的基础
jvm·数据库·python
泯仲3 小时前
从零起步学习MySQL 第十二章:MySQL分页性能如何优化?
数据库·学习·mysql
IvorySQL3 小时前
直播预告|PostgreSQL 18.3 x IvorySQL 5.3:开启 AI 数据库新纪元
数据库·postgresql·开源
TDengine (老段)3 小时前
TDengine IDMP 组态面板 —— 创建组态
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
SelectDB3 小时前
Apache Doris + SelectDB:定义 AI 时代,实时分析的三大范式
大数据·数据库·数据分析