首 页  资讯中心 下载中心 资讯教程 最新下载 发布软件 发布文章 网通站 电信站繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:曾子源码软件下载站 -> 数据库 -> MySQL -> 文章内容 退出登录 用户管理
热门文章
· 常用C,VC,C++书籍下..
· 新概念英语视频教程..
· 常用 JAVA JAVA2 J..
· 《梦幻麻将馆9雀圣争..
· 新东方英语视频教程..
· 常用VB,Visual Basi..
· [组图] After Effect..
· WINDOWS 所有系统文..
· [组图] 让机器运行多..
· 全美经典学习指导系..
相关文章
· my123爆发 360安全卫..
· [组图] Photoshop光影..
· 初学入门 PHP 和 My..
· MySQL安全问题(匿名..
· ASP使用MYSQL数据库..
· mysql获得系统权限
· [组图] IIS实现ASP,C..
· 学习使用数据库MySQ..
· MySQL的转义字符“\..
· 怎样在UNIX系统下安..
MySQL 5.0 触发器
作者:无从考证  来源:转载  发布时间:2005-12-29 23:39:00  发布人:我爱源码

减小字体 增大字体

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’条件的动作都会失败:转载请注明翻译者陈朋奕及转自:www.phpv.net


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不会去实现这些的。转载请注明翻译者陈朋奕及转自:www.phpv.net


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

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.

上一页  [1] [2] [3] 

[] [返回上一页] [打 印] [收 藏]
下一篇文章:MySQL常见错误问答!
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [发表评论...]
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 网站信息排名查询
Copyright © 2004-2006 Zasp.Net. All Rights Reserved .