• 使用存储过程


    什么是存储过程

    存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批文件。尽管他们的作用不仅限于批处理。像定义了一个函数,能够传入传出參数,函数内部进行一定的计算。(本文是针对MySQL进行学习和试验的)

    为什么要使用存储过程

    1. 通过把处理封装在easy使用的单元中。简化复杂的操作
    2. 因为不要求重复建立一系列处理步骤。这保证了数据的完整性。

    3. 简化对变动的管理。

    创建存储过程

    创建一个很easy的存储过程,返回产品平均价格的存储过程:

    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能够查看存储过程状态:




  • 相关阅读:
    <s:iterator>各种遍历用法
    hibernate4整合spring3事务问题
    web服务器部署过程记录
    svn一次性add/delete所有文件
    svn回退版本/取消修改
    sdk接入
    论坛遇到附件上传失败问题总结(discuz)
    linux下部署monogoDB服务(以及安装php mogodb扩展)
    linux部署svn服务器
    linux下给php安装memcached及memcache扩展(转)
  • 原文地址:https://www.cnblogs.com/llguanli/p/7077744.html
Copyright © 2020-2023  润新知