mysql怎么查看触发器 mysql查看触发器创建语句

关于使用mysql的触发器CREATE TRIGGER autoadd AFTER insert ON empl for each row
insert into user set id=new.id;
mysql数据库触发器,怎么做满足条件触发建立两个单域的表格 。一个表格中为姓名列表(表格名:data) 。
另一个表格中是所插入字符的字符数(表格名:chars) 。在data表格中定义一个触发器 。
每次在其中插入一个新姓名时,chars表格中运行的总数就会根据新插入记录的字符数目进行自动更新 。
(见列表A)
mysql CREATE TABLE data (name VARCHAR(255));
Query OK, 0 rows affected (0.09 sec)
mysql CREATE TABLE chars (count INT(10));
Query OK, 0 rows affected (0.07 sec)
mysql INSERT INTO chars (count) VALUES (0);
Query OK, 1 row affected (0.00 sec)
mysql CREATE TRIGGER t1 AFTER INSERT ON
data FOR EACH ROW UPDATE chars SET count = count + CHAR_LENGTH(NEW.name);
Query OK, 0 rows affected (0.01 sec)
列表A
理解上面代码的关键在于CREATE TRIGGER命令,被用来定义一个新触发器 。这个命令建立一个新触发器,假定的名称为t1,每次有一个新记录插入到data表格中时,t1就被激活 。
在这个触发器中有两个重要的子句:
AFTER INSERT子句表明触发器在新记录插入data表格后激活 。
UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)子句表示触发器激活后执行的SQL命令 。在本例中,该命令表明用新插入的data.name域的字符数来更新 chars.count栏 。这一信息可通过内置的MySQL函数CHAR_LENGTH()获得 。
放在源表格域名前面的NEW关键字也值得注意 。这个关键字表明触发器应考虑域的new值(也就是说 , 刚被插入到域中的值) 。MySQL还支持相应的OLD前缀 , 可用它来指域以前的值 。
可以通过调用SHOW TRIGGER命令来检查触发器是否被激活,如列表B所示 。
mysql SHOW TRIGGERS\G
*************************** 1. row ***************************
?Trigger: t1
?Event: INSERT
?Table: data
Statement: UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)
Timing: AFTER
?Created: NULL
ql_mode:
1 row in set (0.01 sec)
列表B
【mysql怎么查看触发器 mysql查看触发器创建语句】激活触发器后 , 开始对它进行测试 。试着在data表格中插入几个记录:
mysql INSERT INTO data (name) VALUES ('Sue'), ('Jane');
Query OK, 2 rows affected (0.00 sec)
Records: 2?Duplicates: 0?Warnings: 0
然后检查chars表格看触发器是否完成它该完成的任务:
mysql SELECT * FROM chars;
+-------+
| count |
+-------+
| 7|
+-------+
1 row in set (0.00 sec)
data表格中的INSERT命令激活触发器,计算插入记录的字符数,并将结果存储在chars表格中 。如果往data表格中增加另外的记录,chars.count值也会相应增加 。
触发器应用完毕后,可有DROP TRIGGER命令轻松删除它 。
mysql DROP TRIGGER t1;
Query OK, 0 rows affected (0.00 sec)
注意:理想情况下,你还需要一个倒转触发器,每当一个记录从源表格中删除时,它从字符总数中减去记录的字符数 。这很容易做到,你可以把它当作练习来完成 。提示:应用BEFORE DELETE ON子句是其中一种方法 。
现在,要建立一个审计记录来追踪对这个表格所做的改变 。这个记录将反映表格的每项改变,并向用户说明由谁做出改变以及改变的时间 。需要建立一个新表格来存储这一信息(表格名:audit),如下所示 。(列表C)
mysql CREATE TABLE audit (id INT(7), balance FLOAT, user VARCHAR(50)
NOT NULL, time TIMESTAMP NOT NULL);
Query OK, 0 rows affected (0.09 sec)
列表C
接下来,我将在accounts表格中定义一个触发器 。(列表D)

推荐阅读