什么是存储过程存储过程简单来说,就是为以后的使用而保存的一条或多条mysql语句的集合。可将其视为批文件,虽然他们的作用不仅限于批处理。像定义了一个函数,可以传入传出参数,函数内部进行一定的计算。(本文是针对mysql进行学习和试验的)为什么要使用存储过程1. 通过把处理封装在容易使用的单元中,简化复杂的操作 2. 由于不要求反复建立一系列处理步骤,这保证了数据的完整性。 3. 简化对变动的管理。创建存储过程创建一个非常简单的存储过程,返回产品平均价格的存储过程:
create procedure productpricing() begin select avg(prod_price) as priceaverage from products; end//
调用存储过程比较简单:
删除存储过程: drop procedure productpricing;
使用参数例1以下是productpricing的修改版本 create procedure productpricing( out pl decimal(8,2), out ph decimal(8,2), out pa decimal(8,2) ) begin select min(prod_price) into pl from products; select max(prod_price) into ph from products; select avg(prod_price) into pa from products; end//
调用存储过程 call productpricing(@pricelow, @pricehigh, @priceaverage)//
显示调用结果:
例2下面这个例子比较有实际意义,创建一个存储过程,传入订单号,返回该订单总金额:
create procedure ordertotal( in onumber int, out ototal decimal(8,2) ) begin select sum(item_price*quantity) from orderitems where order_num = onumber into ototal; end //
调用存储过程:
call ordertotal(20005, @total) //
显示结果;
建立智能存储过程考虑建立如下存储过程,计算订单合计,不过对该订单要加增值税,但是又不是针对所有顾客都要加增值税。因此有如下工作: 1. 获得合计 2. 把增值税有条件的添加到合计 3. 返回合计
存储过程的完整工作如下:
调用该存储过程时需要输入订单编号,是否收税,最后的结果存在哪里:
使用show procedure status可以查看存储过程状态:
