MySQL 5.0触发器参考教程第44页


本文整理自网络,侵删。


  例如:

CREATE TABLE t25(s1 INT, s2 CHAR(5), PRIMARY KEY (s1),
CHECK (LEFT(s2,1)='A'))
ENGINE=INNODB;
  这里CHECK的意思是"当s2列的最左边的字符不是'A'时,insert和update语句都会非法",MySQL的视图不支持CHECK,我个人是很希望它能支持的。但如果你很需要在表中使用这样的功能,我建议大家使用触发器来实现。

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;//
  我只需要使用BEFORE INSERT和BEFORE UPDATE语句就行了,删除了触发器不会对表有影响,同时AFTER的触发器也不能修改NEW的过程变量(transition variables)。为了激活触发器,我执行了向表中的行插入s1=0的数据,之后只要执行符合LEFT(s2,1) <> 'A'条件的动作都会失败:

  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

  该抛弃旧的MySQL的手册了

  我在这里警告大家不要相信过去的MySQL手册中所说的了。我们已经去掉了关于触发器的错误的语句,但是仍旧有很多旧版本的手册在网上,举个例子,这是一个德国的Url上的:

  http://dev.mysql.com/doc/mysql/de/ANSI_diff_Triggers.html.

  这个手册上说触发器就是存储过程,忘掉吧,你也已经看见了,触发器就是触发器,而存储过程还是存储过程。

  手册上还说触发器可以从其他表上来删除,或者是当你删除一个事务的时候激发,无论他说的是什么意思,忘掉吧,MySQL不会去实现这些的。

  最后关于说使用触发器会对查询速度产生影响的说法也是错的,触发器不会对查询产生任何影响。

  Bugs

  (不好的东西就不翻译了)

  On December 14 2004, I did an "Advanced Search" in http://bugs.mysql.com for 'trigger' or

  'triggers', I found that there were 17 active bugs as of that date. Of course they might disappear

  before you read this, but just in case they haven't, I'll mention the important ones. If they're still

  there, you'll have to work around them when you're trying triggers.

  Bug#5859 DROP TABLE does not drop triggers.

  (删除表的时候没有自动删除触发器)

  When you drop a table, dropping the table's triggers should be automatic.

  Bug#5892 Triggers have the wrong namespace.


  (触发器的命名空间有错,你必须在前面加上表的名字才能删除触发器,下面是例子)

  You have to say "DROP TRIGGER <table name> . <trigger name>".

  The correct way is "DROP TRIGGER <trigger name>".

  Bug#5894 Triggers with altered tables cause corrupt databases.

  (触发器对表的改变可能会造成数据库数据被破坏)

  Do not alter a table that has a trigger on it, until you know this is fixed.
上一页1234阅读全文

更多Mysql内容来自木庄网络博客


标签:Mysql

相关阅读 >>

最全mysql数据类型梳理汇总

怎么查本机安装了mysql

通过mysql导出查询结果到csv方法的讲解

mysql启动创建不了pid是什么原因

mysql数据存储过程参数实例详解

一些常用的mysql优化方法总结

mysql 数据库导入导出命令

mysql常见优化方案汇总

mysql调优之profile的使用方法

mysql创建索引有什么技巧

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    正在狠努力加载,请稍候...