mysql触发器(Trigger)简明总结和使用实例


当前第2页 返回上一页

代码如下:

CREATE TABLE `comment` ( 
`c_id` int(11) NOT NULL auto_increment COMMENT '评论ID', 
`u_id` int(11) NOT NULL COMMENT '用户ID', 
`name` varchar(50) NOT NULL default '' COMMENT '用户名称', 
`content` varchar(1000) NOT NULL default '' COMMENT '评论内容', 
PRIMARY KEY  (`c_id`) 
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 ; 

INSERT INTO `comment` (`c_id`, `u_id`, `name`, `content`) VALUES 
(1, 1, '张映', '触发器测试'), 
(2, 1, '张映', '解决字段冗余'), 
(3, 2, 'tank', '使代码更简单'); 

在这里有一个冗余字段name,我们在读取评论进可以用联合查寻来找到user表中的名字,为什么要有冗余字段呢,因简单的sql语句执行效率更高,但不是冗余字段越多越好,冗余字段多了,同样会增加数据库负担 .
我要做的事情是,当我更新user表的name时,触发器同时更新comment表,就不要写php代码去更新了,当用户被删除时,comment表中,有关该用户的数据将被删除

3,更新name触发器

代码如下:

delimiter ||      //mysql 默认结束符号是分号,当你在写触发器或者存储过程时有分号出现,会中止转而执行 
drop trigger if exists updatename||    //删除同名的触发器, 
create trigger updatename after update on user for each row   //建立触发器, 
begin 
//old,new都是代表当前操作的记录行,你把它当成表名,也行; 
if new.name!=old.name then   //当表中用户名称发生变化时,执行 
update comment set comment.name=new.name where comment.u_id=old.id; 
end if; 
end|| 
delimiter ;

4,触发器删除comment数据

代码如下:

delimiter || 
drop trigger if exists deletecomment|| 
create trigger deletecomment before delete on user for each row 
begin 
delete from comment where comment.u_id=old.id; 
end|| 
delimiter ; 

有一点很让人郁闷,就是写好的触发器代码,不能修改,你要删除掉重建,郁闷中,对了还有一点就是phpmyadmin,有的能创建触发器,有的不能,有的能创建,但创建了看不到。在研究一下。

5,测试触发器是否可用

a,测试updata触发器

代码如下:
update user set name='苍鹰'  where id = 1;
更新后去comment表里面看看,里面name字段里面的段有没有改变

b,测试delete触发器

代码如下:
delete from user  where id = 1;
更新后去comment表里面看看,里面name字段里面的段有没有改变

四,触发器的优点

1,触发器的"自动性"
对程序员来说,触发器是看不到的,但是他的确做事情了,如果不用触发器的话,你更新了user表的name字段时,你还要写代码去更新其他表里面的冗余字段,我举例子,只是一张表,如果是几张表都有冗余字段呢,你的代码是不是要写很多呢,看上去是不是很不爽呢。
2,触发器的数据完整性
触发器有回滚性,举个例子,我发现我很喜欢举子,就是你要更新五张表的数据,不会出现更新了二个张表,而另外三张表没有更新。
但是如果是用php代码去写的话,就有可能出现这种情况的,比如你更新了二张表的数据,这个时候,数据库挂掉了。你就郁闷了,有的更新了,有的没更新。这样页面显示不一致了,变有bug了。

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


标签:Mysql

返回前面的内容

相关阅读 >>

mysql数据库进行连接的简单示例代码

navicat121 mysql怎么破解

与mssql对比学习mysql的心得(一)--基本语法

用xtrabackup备份mysql数据库方法指导

linux下怎么打开mysql数据库

mysql怎么导入数据?

关于django中mysql的charset配置

mysql两种引擎的有什么区别

mysql使用变量实现各种排序实例详解

navicat连接mysql出现错误1045如何解决

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


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

数据库系统概念 第6版

机械工业出版社

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



打赏

取消

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

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

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

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

评论

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