MySQL 5.0 触发器

2016-01-29 15:08 12 1 收藏

MySQL 5.0 触发器,MySQL 5.0 触发器

【 tulaoshi.com - MySQL 】

Conventions and Styles约定和编程风格
每次我想要演示实际代码时,我会对mysql客户端的屏幕就出现的代码进行调整,将字体改成Courier,使他们看起来与普通文本不一样(让大家区别程序代码和正文)。在这里举个例子:

mysql DROP FUNCTION f;
Query OK, 0 rows affected (0.00 sec)

如果实例比较大,则需要在某些行和段落间加注释,同时我会用将"<--"符号放在页面的右边以表示强调。例如:

mysql CREATE PROCEDURE p ()
- BEGIN
- /* This procedure does nothing */ <--
- END;//
Query OK, 0 rows affected (0.00 sec)

有时候我会将例子中的"mysql"和"-"这些系统显示去掉,你可以直接将代码复制到mysql客户端程序中(如果你现在所读的不是电子版的,可以在mysql.com网站下载相关脚本)

所以的例子都已经在Suse 9.2 Linux、Mysql 5.0.3公共版上测试通过。在您阅读本书的时候,Mysql已经有更高的版本,同时能支持更多OS了,包括Windows,Sparc,HP-UX。因此这里的
例子将能正常的运行在您的电脑上。但如果运行仍然出现故障,可以咨询你认识的资深Mysql用户,这样就能得到比较好的支持和帮助。转载请注明翻译者陈朋奕及转自:www.phpv.net


Why Triggers 为什么要用触发器

我们在MySQL 5.0中包含对触发器的支持是由于以下原因:

MySQL早期版本的用户长期有需要触发器的要求。
我们曾经许诺支持所有ANSI标准的特性。
您可以使用它来检查或预防坏的数据进入数据库。
您可以改变或者取消INSERT, UPDATE以及DELETE语句。
您可以在一个会话中监视数据改变的动作。

在这里我假定大家都读过"MySQL新特性"丛书的第一集--"MySQL存储过程",那么大家都应该知道MySQL至此存储过程和函数,那是很重要的知识,因为在触发器中你可以使用在函数中使用的语句。特别举个例子:

复合语句(BEGIN / END)是合法的.转载请注明翻译者陈朋奕及转自:www.phpv.net

流控制(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

在触发器中也有完全一样的限制.

触发器相对而言比较新,因此会有(bugs)缺陷.所以我在这里给大家警告,就像我在存储过程书中所说那样.不要在含有重要数据的数据库中使用这个触发器,如果需要的话在一些以测试为目的的数据库上使用,同时在你对表创建触发器时确认这些数据库是默认的。
 
Syntax 语法
1. Syntax: Name 语法:命名规则转载请注明翻译者陈朋奕及转自:www.phpv.net


CREATE TRIGGER <触发器名称               <--
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称
FOR EACH ROW
<触发器SQL语句

触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.

这里我有个习惯:就是用表的名字+’_’+触发器类型的缩写.因此如果是表t26,触发器是在事件UPDATE(参考下面的点(2)和(3))之前(BEFORE)的,那么它的名字就是t26_bu。
 
2. Syntax: Time 语法:触发时间

CREATE TRIGGER <触发器名称
{ BEFORE | AFTER } <--
{ INSERT | UPDATE | DELETE }
ON <表名称
FOR EACH ROW
<触发的SQL语句

触发器有执行的时间设置:可以设置为事件发生前或后。
 

本新闻共3页,当前在第1页&nb

来源:https://www.tulaoshi.com/n/20160129/1495343.html

延伸阅读
标签: MySQL mysql数据库
在SQL中,名词触发器指“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据...
标签: MySQL mysql数据库
在SQL中,名词触发器指“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据...
标签: 电脑入门
触发器存在于自定义动画的计时选项中,是wps演示中的一项很重要的功能,作用是通过触发来实现播放设置对象动画,实现交互的目的。 触发器当然是有触而发,不触发设置触发器的对象,触发器下设置的一些动画就不会播放,在编辑状态可以通过标记发现触发器的存在。 打开带有触发器的wps演示文稿。执行幻灯片放映 自定义动画命令,打开自定义动...
标签: 电脑入门
有朋友问什么是PPT触发器,从原理上讲其实很简单,微软官方给出的解释是:PPT触 发器仅仅是PPT中的一项功能,它可以是一个图片、图形、按钮,甚至可以是一个段落或文本框,单击触发器时它会触发一个操作,该操作可能是声音、电影或动 画。而我对PPT触发器的理解为:通过按钮点击控制PPT页面中已设定动画的执行(读起来相当拗口,但应用才是...
触发器的概念:“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。当一个新整数值增加到数据库域中时...

经验教程

96

收藏

74
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部