mysql进阶之存储过程

存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。
可将其视为批文件,虽然它们的作用不仅限于批处理。

存储过程的优点:
1. 把处理封装在容易使用的单元中,简化复杂的操作。
2. 不要求反复建立一系列处理步骤,这保证了数据的完整性。团队开发过程中,所有开发人员和应用程序都使用同一(试验和测试)存储过程,则所使用的代码都是相同的,也可达到防止错误的效果。
3. 简化对变动的管理。如果表名、列名或业务逻辑(或别的内容)有变化,只需要更改存储过程的代码。
4. 提高性能。使用存储过程比使用单独的SQL语句要快。
5. 存在一些只能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码
简单总结: 简单、安全、高性能。


1. 如何执行存储过程:
利用Call关键字,CALL接受存储过程的名字以及需要传递给它的任意参数。

CALL productPricing(@avgPrice, @avgSum);

如下:
在这里插入图片描述

注意:
1. 第一次调用时,应该按照(1 -> 2)的顺序执行
2. 如果已经调用过一次,但是期间更改过创建存储过程中的sql执行语句,那么需要先执行3删除已经创建的存储过程,然后在依次执行1 ,2, 否则结果无法更新甚至会报‘PROCEDURE productPricing already exists’的错误。
在这里插入图片描述


2. 创建并执行带参数的存储过程

IN(传递给存储过程)、 OUT(从存储过程传出)和INOUT(对存储过程传入和传出)类型的参数。


CREATE PROCEDURE productInfo(
	OUT p1 float(8, 2),
	OUT p2 DECIMAL(8, 2)
)
BEGIN
	SELECT help_topic_id into p1 from help_topic where name = 'CONTAINS';
	SELECT help_topic_id into p2 from help_topic where name = 'HEX'; 
END;

CALL productInfo(@p1, @p2);
SELECT @p1 as p1, @p2 as p2;

执行结果:
在这里插入图片描述


3. 建立并执行智能存储过程

CREATE PROCEDURE productInfo(
	IN p1 float(8, 2),
	OUT p2 DECIMAL(8, 2)
)
BEGIN
	if p1 = 'CONTAINS' then
		SELECT help_topic_id into p2 from help_topic where name = 'CONTAINS'; 
	else 
		SELECT help_topic_id into p2 from help_topic where name = 'HEX'; 
	END IF;
END;

CALL productInfo('CONTAINS', @p2);
SELECT @p2 as p2;

执行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值