首页 > 代码库 > mysql之存储过程和触发器的应用

mysql之存储过程和触发器的应用

存储例程:

       存储例程是存储在数据库服务器中的一组sql语句,通过在查询中调用一个指定的名称来执行这些sql语句命令。

使用场景:

       我们的应用程序分为两种:一种基于web,一种是基于桌面,他们都和数据库进行交互来完成数据的存取工作。假设有一种应用程序包含了这两种,现在要修改其中的一个查询sql语句,那么我们可能要同时修改他们中对应的sql语句,当我们的应用程序很庞大很负载的时候问题就出现了,不易维护!另外sql查询放到我们的web程序或桌面中易于遭到sql注入的破坏。而存储过程正好可以帮我们解决这个问题。

     mysql中的存储例程包含了存储过程和存储函数,他们统称为存储例程

     存储过程主要完成在获取记录或插入记录或更新记录或删除记录,即完成select,insert,delete,update等

     存储函数只完成查询的工作,可接受输入参数并返回一个结果

     查询数据库的所有存储过程:SHOWPROCEDURE  STATUS

     存储过程语法:

         DEMILITER $$ --重定义分割符

              CREATE PROCEDURE sp_name()

              begin  --区块定义开始

                ......

              end --区域定义结束

              $$  --定义的分割符

         删除存储过程:DROP PROCEDURE procedure_name

         变量定义:局部变量声明一定放在存储过程体的开始

             DECLARE variable_name  [,variable_name...]  DATATYPE  [default value]

             datatype 为MySQL的数据类型,如int,float,date,varchar(length)

             例子:DECLARE  l_int  int  unsighed  default  40000;

          变量赋值:

               SET  变量名  = 表达式   [,variable_name = expression ...]


触发器:

       不用想存储过程需要再程序中进行调用,是在INSERT/PUDATE/DELETE等DML语句修改数据表时触发。

       应用场景:重要的业务逻辑、提高性能、监控表的修改等

       语法:

        DELIMITER $$

         CREATE TRIGGER tri_stuname   --触发器名称

         trigger_time  --触发时机 取值为before/after

         trigger_event -- 触发时间,取值为INSERT/UPDATE/DELETE;  ON tbl_name --建立触发器的表名

         FOR EACH ROW

         trigger_stmt --触发器程序体, begin  ....end

       实例:

           DELIMITER $
               create trigger tri_stuInsert after insert
               on student for each row
               begin
               declare c int;
               set c = (select stuCount from class where classID=new.classID);
               update class set stuCount = c + 1 where classID = new.classID;
               end$
          DELIMITER ;

        


mysql之存储过程和触发器的应用