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;

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

发布了27 篇原创文章 · 获赞 4 · 访问量 6287

猜你喜欢

转载自blog.csdn.net/studentenglish/article/details/95236750