触发器
来源:互联网 发布:台球厅计时软件 编辑:程序博客网 时间:2024/06/11 06:15
触发器
BEFORE 之前 AFTER 之后
1.在person表中创建触发器t1,当向person表中插入一条记录时触发.
触发执行动作为:更新number表中count字段值加一
mysql> DELIMITER //
mysql> CREATE TRIGGER t1
-> AFTER
-> INSERT ON person
-> FOR EACH ROW
-> BEGIN
-> declare c int;
-> set c=(SELECT count FROM number);
-> UPDATE number set count=c+1;
-> END
-> //
1.在person表中创建触发器t1,当向person表中插入一条记录时触发.
触发执行动作为:更新number表中count字段值加一
mysql> DELIMITER //
mysql> CREATE TRIGGER t1
-> AFTER
-> INSERT ON person
-> FOR EACH ROW
-> BEGIN
-> declare c int;
-> set c=(SELECT count FROM number);
-> UPDATE number set count=c+1;
-> END
-> //
2.在person表中创建触发器t2,当向person表中删除一条记录时触发.
触发执行动作为:更新number表中count字段值减一
mysql> DELIMITER //
mysql> CREATE TRIGGER t2
-> AFTER DELETE ON person
-> FOR EACH ROW
-> BEGIN
-> declare c int;
-> set c = (select count from number);
-> UPDATE number SET count=c-1;
-> END
-> //
触发执行动作为:更新number表中count字段值减一
mysql> DELIMITER //
mysql> CREATE TRIGGER t2
-> AFTER DELETE ON person
-> FOR EACH ROW
-> BEGIN
-> declare c int;
-> set c = (select count from number);
-> UPDATE number SET count=c-1;
-> END
-> //
3.查看触发器
和查看数据库(show databases;)查看表格(show tables;)一样,查看触发器的语法如下:
SHOW TRIGGERS [FROM schema_name];
SHOW TRIGGERS [FROM schema_name] \G; //格式化输出
示例:
SHOW TRIGGERS \G; //格式化显示当前数据库所有触发器
4.删除触发器
和删除数据库、删除表格一样,删除触发器的语法如下:
DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name
示例:
DROP TRIGGER IF EXISTS t1; //删除触发器t1
和查看数据库(show databases;)查看表格(show tables;)一样,查看触发器的语法如下:
SHOW TRIGGERS [FROM schema_name];
SHOW TRIGGERS [FROM schema_name] \G; //格式化输出
示例:
SHOW TRIGGERS \G; //格式化显示当前数据库所有触发器
4.删除触发器
和删除数据库、删除表格一样,删除触发器的语法如下:
DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name
示例:
DROP TRIGGER IF EXISTS t1; //删除触发器t1
2.NEW 与 OLD 详解
上述示例中使用了NEW关键字,和 MS SQL Server 中的 INSERTED 和 DELETED 类似,MySQL 中定义了 NEW 和 OLD,用来表示
触发器的所在表中,触发了触发器的那一行数据。
具体地:
在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据;
使用方法: NEW.columnName (columnName 为相应数据表某一列名)
另外,OLD 是只读的,而 NEW 则可以在触发器中使用 SET 赋值,这样不会再次触发触发器,造成循环调用(如每插入一个学生前,都在其学号前加“2013”)。
阅读全文
0 0
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 触发器
- 高阶篇:4.5)FMEA手册的疑问与不足(个人观点);
- Spring加载properties文件的两种方式
- 微信小程序基础库版本大小判断
- CSS高度自适应!
- apply方法和unapply方法
- 触发器
- openCV学习笔记
- Java学习笔记--cmd编译运行小坑
- python 列出指定目录下的所有目录和文件
- strlen()函数和strcat()函数
- Git分支管理
- selenium 基本方法使用二_javascript的应用_对滚动条的操作
- js跨域详解
- 红黑树深入剖析及Java实现(图文并茂娓娓道来)