mysql的触发器怎么做 mysql触发器工作原理

mysql如何用触发器禁止某条记录的删除、修改mysql用触发器禁止某条记录的删除、修改:
delimiter //
CREATE TRIGGER xx_company_agent_updateBEFORE UPDATE ON xx_company_agent
FOR EACH ROW
BEGIN
IF OLD.bank_card is not null THEN
SET NEW.bank_card = OLD.bank_card,NEW.money= OLD.money,NEW.real_money=OLD.real_money,NEW.bank_name=OLD.bank_name;
END IF;
END;//
delimiter ;
扩展资料
mysql触发器的使用
用户记录用户的预期事件(schema是特殊用户的数据库对象集合 。这些对象包括:表,索引,视图,存储程序等 。在Oracle里,schema要求创建一个用户 。但是也可以创建一个没有schema的用户(根本没有对象) 。
所以在Oracle-中 , 用户就是一个帐户而schema就是对象 。可能在其他的数据库平台上可以创建一个没有用户的schema 。LOGOFF不能是AFTER LOGOFF,将会重新操作,这里应该是BEFORE,否则就会报错:替换可以插入不能有AFTER 。创建或替换触发器MYLOGOFFTRIGGER 。
参考资料来源:百度百科—mySQL
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
激活触发器后 , 开始对它进行测试 。试着在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值也会相应增加 。

推荐阅读