约定和编程风格 每次我想要演示实际代码时,我会对mysql客户端的屏幕就出现的代码进行调整,将字体改成Courier,使他们看起来与普通文本不一样(让大家区别程序代码和正文)。在这里举个例子: mysql DROP FUNCTION f;Query OK, 0 rows affected (0.00 sec)
约定和编程风格mysql> DROP FUNCTION f; Query OK, 0 rows affected (0.00 sec)
MySQL早期版本的用户长期有需要触发器的要求。 我们曾经许诺支持所有ANSI标准的特性。 您可以使用它来检查或预防坏的数据进入数据库。 您可以改变或者取消INSERT, UPDATE以及DELETE语句。 您可以在一个会话中监视数据改变的动作。
复合语句(BEGIN / END)是合法的. 流控制(Flow-of-control)语句(IF, CASE, WHILE, LOOP, WHILE, REPEAT, LEAVE,ITERATE)也是合法的. 变量声明(DECLARE)以及指派(SET)是合法的. 允许条件声明. 异常处理声明也是允许的. 但是在这里要记住函数有受限条件:不能在函数中访问表. 因此在函数中使用以下语句是非法的。 ALTER 'CACHE INDEX' CALL COMMIT CREATE DELETE DROP 'FLUSH PRIVILEGES' GRANT INSERT KILL LOCK OPTIMIZE REPAIR REPLACE REVOKE ROLLBACK SAVEPOINT 'SELECT FROM table' 'SET system variable' 'SET TRANSACTION' SHOW 'START TRANSACTION' TRUNCATE UPDATE 在触发器中也有完全一样的限制.
1. 语法:命名规则 CREATE TRIGGER FOR EACH ROW
2. 语法:触发时间 CREATE TRIGGER { BEFORE | AFTER } FOR EACH ROW 触发器有执行的时间设置:可以设置为事件发生前或后。 3. 语法:事件 CREATE TRIGGER { BEFORE | AFTER } { INSERT | UPDATE | DELETE } FOR EACH ROW 同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。 4. 语法:表 CREATE TRIGGER { BEFORE | AFTER } { INSERT | UPDATE | DELETE } ON 触发器是属于某一个表的:当在这个表上执行插入、 更新或删除操作的时候就导致触发器的激活. 我们不能给同一张表的同一个事件安排两个触发器。 5. 语法:( 步长)触发间隔 CREATE TRIGGER { BEFORE | AFTER } { INSERT | UPDATE | DELETE } ON FOR EACH ROW 触发器的执行间隔:FOR EACH ROW子句通知触发器 每隔一行执行一次动作,而不是对整个表执行一次。 6. 语法:语句 CREATE TRIGGER { BEFORE | AFTER } { INSERT | UPDATE | DELETE } ON FOR EACH ROW TO ; 也可以通过这样收回权限: REVOKE CREATE TRIGGER ON FROM ;
CREATE TRIGGER t21_au BEFORE UPDATE ON t22 FOR EACH ROW BEGIN SET @old = OLD . s1; SET @new = NEW.s1; END;// 现在如果t21表中的s1列的值是55,那么执行了 "UPDATE t21 SET s1 = s1 + 1"之后@old的值会变成55, 而@new的值将会变成56。
Example of CREATE and INSERT CREATE和INSERT的例子 创建有触发器的表 这里所有的例程中我都假定大家的分隔符已经设置成//(DELIMITER //)。 CREATE TABLE t22 (s1 INTEGER)// CREATE TRIGGER t22_bi BEFORE INSERT ON t22 FOR EACH ROW BEGIN SET @x = 'Trigger was activated!'; SET NEW.s1 = 55; END;//
mysql> SELECT @x, t22.* FROM t22// +------------------------+------+ | @x | s1 | +------------------------+------+ | Trigger was activated! | 55 | +------------------------+------+ 1 row in set (0.00 sec)
"check"完整性约束例子 什么是"check"约束 在标准的SQL语言中,我们可以在(CREATE TABLE)创建表的过程中使用"CHECK (condition)", 例如: CREATE TABLE t25 (s1 INT, s2 CHAR(5), PRIMARY KEY (s1), CHECK (LEFT(s2,1)='A')) ENGINE=INNODB;
CREATE TABLE t25 (s1 INT, s2 CHAR(5), PRIMARY KEY (s1)) ENGINE=INNODB// CREATE TRIGGER t25_bi BEFORE INSERT ON t25 FOR EACH ROW IF LEFT(NEW.s2,1)'A' THEN SET NEW.s1=0; END IF;// CREATE TRIGGER t25_bu BEFORE UPDATE ON t25 FOR EACH ROW IF LEFT(NEW.s2,1)'A' THEN SET NEW.s1=0; END IF;//
INSERT INTO t25 VALUES (0,'a') /* priming the pump */ // INSERT INTO t25 VALUES (5,'b') /* gets error '23000' */ // Don't Believe The Old MySQL Manual