mysql 触发器学习
2015-06-22 17:27
627 查看
1. 一个简单的例子
1.1. 创建表:
create table t(s1 integer);
1.2. 触发器:
1.3. 如果触发器创建错误,可能只能删除了,至少我试过不能replace
drop trigger t_trigger;
1.4. 当执行insert 时:
insert into t values(1);
1.5. 会执行触发器t_trigger
select @x,t.* from t;
1.6. 可以看到结果:
![](http://pic002.cnblogs.com/images/2011/310459/2011072510491110.png)
1.7可以使用 SHOW TRIGGERS; 查看新建的触发器
2. url查询哈希值的维护 触发器
2.1 创建表 pseudohash。
![](http://pic002.cnblogs.com/images/2011/310459/2011072511010791.png)
2.2 创建触发器,当对表进行插入和更新时,触发 触发器
2.3 插入操作
insert into pseudohash(url) values("http://www.baidu.com");
insert into pseudohash(url) values("http://www.163.com");
2.4 查看表中数据(是进行更新操作之后的数据)
![](http://pic002.cnblogs.com/images/2011/310459/2011072511042728.png)
2.5 更新
update pseudohash set url = 'www.163.com' where id = 1;
可以看到的是,插入和更新操作后,他们的 url_crc是不同的
----------------------------------------------------------------------------
2.6 上面源于一个 对于url建立索引的例子,还有一种建立索引的方式: 在B+ 树上建立一个伪索引,和真正的索引不同,它还是在B+树 索引上进行查找,但是,使用的是 键的哈希值进行查找,而不是键本身,这样会加快查找
2.6.1 创建urls 表,注意使用的是 memory存储引擎
2.6.2 然后插入url和url_crc,例如
insert into urls values('www.gougou.com',crc32('www.gougou.com'));
像上面的那样,或者使用触发器
![](http://pic002.cnblogs.com/images/2011/310459/2011072511335175.png)
2.6.3 然后查询的时候使用 hash索引查询
select * from urls where url = "www.baidu.com" and url_crc = crc32("www.baidu.com");
select * from urls where url_crc = crc32("www.baidu.com");
select * from urls where url = "www.baidu.com"
上面3个查询结果当然是一样的,但是速度上hash的快很多
3. 触发器 语法
3.1 CREATE TRIGGER trigger_name trigger_time trigger_event
trigger_time是触发程序的动作时间。它可以是BEFORE或AFTERtrigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一:
如果你在触发器里面对刚刚插入的数据进行了 insert/update, 会造成循环的调用.
如:
create trigger test before update on test for each row update test set NEW.updateTime = NOW() where id=NEW.ID; END
应该使用set:
create trigger test before update on test for each row set NEW.updateTime = NOW(); END
3.3 触发器 与存储过程
触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL
而存储过程 可以接受参数,将结果范围给应用程序
1.1. 创建表:
create table t(s1 integer);
1.2. 触发器:
drop trigger t_trigger;
1.4. 当执行insert 时:
insert into t values(1);
1.5. 会执行触发器t_trigger
select @x,t.* from t;
1.6. 可以看到结果:
![](http://pic002.cnblogs.com/images/2011/310459/2011072510491110.png)
1.7可以使用 SHOW TRIGGERS; 查看新建的触发器
2. url查询哈希值的维护 触发器
2.1 创建表 pseudohash。
![](http://pic002.cnblogs.com/images/2011/310459/2011072511010791.png)
2.2 创建触发器,当对表进行插入和更新时,触发 触发器
delimiter | create trigger pseudohash_crc_ins before insert on pseudohash for each row begin set @x = "hello trigger"; set NEW.url_crc=crc32(NEW.url); end; | create trigger pseudohash_crc_upd before update on pseudohash for each row begin set @x = "hello trigger"; set NEW.url_crc=crc32(NEW.url); end; | delimiter ;
2.3 插入操作
insert into pseudohash(url) values("http://www.baidu.com");
insert into pseudohash(url) values("http://www.163.com");
2.4 查看表中数据(是进行更新操作之后的数据)
![](http://pic002.cnblogs.com/images/2011/310459/2011072511042728.png)
2.5 更新
update pseudohash set url = 'www.163.com' where id = 1;
可以看到的是,插入和更新操作后,他们的 url_crc是不同的
----------------------------------------------------------------------------
2.6 上面源于一个 对于url建立索引的例子,还有一种建立索引的方式: 在B+ 树上建立一个伪索引,和真正的索引不同,它还是在B+树 索引上进行查找,但是,使用的是 键的哈希值进行查找,而不是键本身,这样会加快查找
2.6.1 创建urls 表,注意使用的是 memory存储引擎
CREATE TABLE `urls` ( `url` varchar(255) DEFAULT NULL, `url_crc` int(11) DEFAULT '0', KEY `url` (`url`) USING HASH ) ENGINE=MEMORY DEFAULT CHARSET=utf8;
2.6.2 然后插入url和url_crc,例如
insert into urls values('www.gougou.com',crc32('www.gougou.com'));
像上面的那样,或者使用触发器
![](http://pic002.cnblogs.com/images/2011/310459/2011072511335175.png)
2.6.3 然后查询的时候使用 hash索引查询
select * from urls where url = "www.baidu.com" and url_crc = crc32("www.baidu.com");
select * from urls where url_crc = crc32("www.baidu.com");
select * from urls where url = "www.baidu.com"
上面3个查询结果当然是一样的,但是速度上hash的快很多
3. 触发器 语法
3.1 CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
trigger_time是触发程序的动作时间。它可以是BEFORE或AFTERtrigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一:
· INSERT:将新行插入表时激活触发程序,例如,通过INSERT、LOAD DATA和REPLACE语句。 · UPDATE:更改某一行时激活触发程序,例如,通过UPDATE语句。 · DELETE:从表中删除某一行时激活触发程序,例如,通过DELETE和REPLACE语句。
3.2 可能遇到的问题
如果你在触发器里面对刚刚插入的数据进行了 insert/update, 会造成循环的调用.
如:
create trigger test before update on test for each row update test set NEW.updateTime = NOW() where id=NEW.ID; END
应该使用set:
create trigger test before update on test for each row set NEW.updateTime = NOW(); END
3.3 触发器 与存储过程
触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL
(允许存储程序通过参数将数据返回触发程序)。
而存储过程 可以接受参数,将结果范围给应用程序
相关文章推荐
- mysql常用函数
- Mysql命令大全
- MySql基础知识、存储引擎与常用数据类型
- 笔记:MySQL初次使用安全设置
- Mysql my.ini 配置文件详解
- MySQL学习笔记
- sql学习笔记(24)----------MySQL的事务处理详解
- sql学习笔记(23)-----------MySQL视图
- 安装、设置与启动MySql绿色版的方法
- sql学习笔记(22)-----------mysql存储过程详解
- mysql计算两个日期相差的天数
- mysql 一次死锁的处理
- mysql格式化时间戳为日期
- 强制修改mysql 中root的密码
- mysql更新表中日期字段时间
- mysql查找一个字段属于哪个表
- 《mysql 必知必会》 笔记(五)
- mysql数据库基础总结
- 《mysql 必知必会》 笔记(四)
- mysql 按周、日进行数据统计