MYSQL触发器

来源:互联网 发布:下载淘宝帐号注册账号 编辑:程序博客网 时间:2024/04/30 14:27

今天在MYSQL的手册上看到了这个:

(1)对于具有相同触发程序动作时间和事件的给定表,不能有两个触发程序。例如,对于某一表,不能有两个BEFORE UPDATE触发程序。但可以有1BEFORE UPDATE触发程序和1BEFORE INSERT触发程序,或1BEFORE UPDATE触发程序和1AFTER UPDATE触发程序。

(2)使用OLDNEW关键字,能够访问受触发程序影响的行中的列(OLDNEW不区分大小写)。在INSERT触发程序中,仅能使用NEW.col_name,没有旧行。在DELETE触发程序中,仅能使用OLD.col_name,没有新行。在UPDATE触发程序中,可以使用OLD.col_name来引用更新前的某一行的列,也能使用NEW.col_name来引用更新后的行中的列。

               用OLD命名的列是只读的。你可以引用它,但不能更改它。对于用NEW命名的列,如果具有SELECT权限,可引用它。在BEFORE触发程序中,如果你具有UPDATE权限,可使用“SET NEW.col_name = value更改它的值。这意味着,你可以使用触发程序来更改将要插入到新行中的值,或用于更新行的值。

(3)BEFORE触发程序中,AUTO_INCREMENT列的NEW0,不是实际插入新记录时将自动生成的序列号。

另外,如果要根据表的变动来调用存储过程,要以将存储过程写在一个触发器中,进行触发调用。

可以在触发器中使用用户自定义变量,来得到触发器中的某个值。

有一个简单的例子:

CREATE TRIGGER insert_change BEFORE
INSERT ON testTable   //testTable 表是一个自增长的ID例和一个NAME例
FOR EACH ROW
BEGIN

SET NEW.name=CONCAT('wei ',NEW.name);

END


INSERT INTO xunhuan VALUES(NULL,'kmjii');

这个触发器的作用是将新插入的列的NAME的值前加上'wei'字符串。

0 0
原创粉丝点击