MySQL 5.0触发器参考教程第4/4页

 更新时间:2008年09月10日 09:20:36   作者:  
需要学习mysql触发器的朋友需要了解的东西,整理的比较多,建议大家慢慢多练习

  例如:

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.

相关文章

  • MySQL找出未提交事务信息的方法分享

    MySQL找出未提交事务信息的方法分享

    这篇文章主要给大家介绍了关于MySQL如何找出未提交事务信息的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • SQL- join多表关联问题

    SQL- join多表关联问题

    这篇文章主要介绍了SQL- join多表关联问题,具有很好的参考价值,希望对大家有所帮助。
    2022-12-12
  • 超详细MySQL使用规范分享

    超详细MySQL使用规范分享

    这篇文章主要介绍了MySQL使用规范,帮助大家更规范的操作MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL禁用InnoDB引擎的方法

    MySQL禁用InnoDB引擎的方法

    这篇文章主要介绍了MySQL禁用InnoDB引擎的方法,针对的Mysql版本是5.5和5.6,使用了两种不同的配置文件,需要的朋友可以参考下
    2014-05-05
  • MySQL 触发器的基础操作(六)

    MySQL 触发器的基础操作(六)

    这篇文章主要为大家详细介绍了MySQL 触发器的基础操作,告诉大家什么是MySQL触发器,如何查看触发器,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • MySQL为什么要避免大事务以及大事务解决的方法

    MySQL为什么要避免大事务以及大事务解决的方法

    这篇文章主要介绍了MySQL为什么要避免大事务以及大事务解决的方法,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • 浅谈mysql导出表数据到excel关于datetime的格式问题

    浅谈mysql导出表数据到excel关于datetime的格式问题

    这篇文章主要介绍了浅谈mysql导出表数据到excel关于datetime的格式问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • 设置MySQLroot账户密码报错ERROR 1064 (42000): You have an error in your SQL syntax;的解决方案

    设置MySQLroot账户密码报错ERROR 1064 (42000): You 

    在安装mysql的时候,设置root账户密码出现了ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds..错误,本文小编给大家介绍了相关的解决方案,需要的朋友可以参考下
    2023-12-12
  • SQL结果如何根据某个字段取最新时间去重

    SQL结果如何根据某个字段取最新时间去重

    在日常的项目开发当中,经常会遇到获取同一属性相同的记录,如何获取记录时间最新的那一条,下面这篇文章主要给大家介绍了关于SQL结果如何根据某个字段取最新时间去重的相关资料,需要的朋友可以参考下
    2023-06-06
  • MySQL SQL性能分析之慢查询日志、explain使用详解

    MySQL SQL性能分析之慢查询日志、explain使用详解

    这篇文章主要介绍了MySQL SQL性能分析 慢查询日志、explain使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04

最新评论