MySQL存储过程、触发器 小例子

时间:2021-08-30 23:15:39

一、存储过程

  语法:  

    CREATE PROCEDURE([[IN |OUT |INOUT ] 参数名 数据类形...])

    BEGIN

      ...

    END

  参数:

   IN 输入参数

    表示该参数的值必须在调用存储过程的时候指定,在存储过程中修改该参数的值不能被返回,为默认值。

   OUT 输出参数

    该值可在存储过程内部被改变,并可返回。

   INOUT 输入输出参数

    调用时指定,并且可被改变和返回。

  

  小例子:

    MySQL存储过程、触发器 小例子

    MySQL存储过程、触发器 小例子

 

 二、触发器

    语法:

      CREATE TRIGGER <触发器名称>    --触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.
      { BEFORE | AFTER }                        --触发器有执行的时间设置:可以设置为事件发生前或后。
      { INSERT | UPDATE | DELETE }       --同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。
      ON <表名称>             --触发器是属于某一个表的:当在这个表上执行插入、 更新或删除操作的时候就导致触发器的激活. 我们不能给同一张表的同一个事件安排两个触发器。
      FOR EACH ROW      --触发器的执行间隔:FOR EACH ROW子句通知触发器 每隔一行执行一次动作,而不是对整个表执行一次。
      <触发器SQL语句>     --触发器包含所要触发的SQL语句:这里的语句可以是任何合法的语句, 包括复合语句,但是这里的语句受的限制和函数的一样。
                     --你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER),如果你已经是Root用户,那么就足够了。这跟SQL的标准有所不同。

    

    小例子:

      1. INSERT 触发器

        student 表中增加学生记录之后,自动将记录增加到 borrowrecord 表中

        MySQL存储过程、触发器 小例子

        MySQL存储过程、触发器 小例子

        MySQL存储过程、触发器 小例子

        MySQL存储过程、触发器 小例子

        MySQL存储过程、触发器 小例子

    

      2.DELETE 触发器

        删除 student 表中的学生记录之后,自动将 borrowrecord 中的相应记录删除。

        MySQL存储过程、触发器 小例子

        MySQL存储过程、触发器 小例子