存储过程简单来说,就是为以后的使用而保存的一条或多条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;
执行结果: