存储过程是MySql 5支持的特性,它是一组为了完成特定功能的SQL语句集,经过编译之后存储在数据库中,当需要使用该组SQL语句时用户只需要通过指定储存过程的名字并给定参数就可以调用执行它了,简而言之就是一组已经写好的命令,需要使用的时候拿出来用就可以了。有点像我们在Java类中写的方法,我们可以根据需要传入参数,调用该方法。
存储过程通常有以下优点:
1)存储过程能实现较快的执行速度。
如果某一操作包含大量的Transaction-SQL代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的。在首次运行一个存储过程时查询,优化器对其进行分析优化,并且给出最终被存储在系统表中的执行计划。而批处理的Transaction-SQL语句在每次运行时都要进行编译和优化,速度相对要慢一些。
心得:编译优化,快!
2)存储过程允许标准组件是编程。
存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。
心得:封装与抽象,简单调用
3)存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。
心得:功能强大,逻辑强大
4)存储过程可被作为一种安全机制来充分利用。
系统管理员通过执行某一存储过程的权限进行限制,能够实现对相应的数据的访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。
心得:限制与安全
5)存储过程能过减少网络流量。
针对同一个数据库对象的操作(如查询、修改),如果这一操作所涉及的Transaction-SQL语句被组织程存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,从而大大增加了网络流量并降低了网络负载。
心得:减少网络流量(封装的好)
如何创建存储过程:
creat procedure avgprice() --没有参数的存储过程,计算平均值
begin
select avg(prod_pice) as priceaverage
from products
end;
call avgprice(); --调用存储过程
创建带有参数的存储过程
第一种:
creat procedure dealPrice(
OUT pa decimal(8,2), --指定参数用来从存储过程传出一个值,decimal表示一种数据类型,指定小数点左边和右边可以存储的十进制数字的最大个数
OUT pb decimal(8,2),
OUT pc decimal(8,2
)
BEGIN
select min(prod_price) into pa from products; --把最小值传给pa
select max(prod_price) into pb from products;
select avg(prod_price) into pc from products;
end;
要调用上面的方法需要指定3个变量名:
CALL dealPrice(@pricelow,@pricehigh,@priceaverage);
调用时这条语句不会显示任何数据,我们可以使用select语句查看
select @priceaverage --查看平均价格
select @pricehigh, @priceaverage, @pricelow; --查看多个值
select 语句要在CALL之后才能使用。
第二种:IN和OUT结合
create procedure ordertotal(
IN onumber int, --接收传入存储过程的订单号
OUT ototal decimal(8,2) --存储过程返回的值
)
BEGIN
select sum(iterm_price*quantity)
from orderiterms
where order_num = onumber
into ototal;
END;
CALL ordertotal(20005,@total); --调用存储过程
select @total --查看返回值
在存储过程中可以使用:
DECLARE在存储过程中声明一个变量,保存存储过程中产生的值,用于下一步计算。
查看存储过程:
SHOW CREATE PROCEDURE ordertotal;
删除存储过程:
DROP PROCEDURE ordertotal;