MYSQL触发器
来源:互联网 发布:下载淘宝帐号注册账号 编辑:程序博客网 时间:2024/04/30 14:27
今天在MYSQL的手册上看到了这个:
(1)对于具有相同触发程序动作时间和事件的给定表,不能有两个触发程序。例如,对于某一表,不能有两个BEFORE UPDATE触发程序。但可以有1个BEFORE UPDATE触发程序和1个BEFORE INSERT触发程序,或1个BEFORE UPDATE触发程序和1个AFTER UPDATE触发程序。
(2)使用OLD和NEW关键字,能够访问受触发程序影响的行中的列(OLD和NEW不区分大小写)。在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列的NEW值为0,不是实际插入新记录时将自动生成的序列号。
另外,如果要根据表的变动来调用存储过程,要以将存储过程写在一个触发器中,进行触发调用。
可以在触发器中使用用户自定义变量,来得到触发器中的某个值。
有一个简单的例子:
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'字符串。
- 【mysql 触发器】触发器使用
- MYSQL 触发器
- mysql 触发器
- Mysql 触发器
- mysql 触发器
- mysql触发器
- MYSQL 触发器
- MySQL触发器
- mysql 触发器
- mysql触发器
- MYSQL 触发器
- mysql 触发器
- mysql 触发器
- MySQL触发器
- MYSQL触发器
- mysql触发器
- mysql触发器
- mysql触发器
- 高并发架构特点
- Centos下安装oracle10g 技术文档
- Gmesh几何模块
- 已测试转开发,博客回归,在路上。
- HexConversion 二进制 八进制 十六进制 十进制
- MYSQL触发器
- Speex 回声消除
- camera 模组驱动优化
- 智能指针的实现
- Java 开发 2.0: 现实世界中的 Redis
- CentOS 6.4 简单方法升级PHP到PHP 5.3.3
- Ubuntu12.04.3 配置nginx-rtmp支持HLS
- 云计算之现状
- iOS Crash文件分析