1. 一個簡單的例子
1.1. 創(chuàng)建表:
create table t(s1 integer);
1.2. 觸發(fā)器:
delimiter |
createtriggert_trigger beforeinsertontforeach row
beginset@x ="hello trigger";
setNEW.s1 = 55;
end;
|
1.3. 如果觸發(fā)器創(chuàng)建錯誤允悦,可能只能刪除了,至少我試過不能replace
drop trigger t_trigger;
1.4. 當執(zhí)行insert 時:
insert into t values(1);
1.5. 會執(zhí)行觸發(fā)器t_trigger
select @x,t.* from t;
1.6. 可以看到結果:
1.7可以使用?SHOW TRIGGERS; 查看新建的觸發(fā)器
2. url查詢哈希值的維護 觸發(fā)器
2.1 創(chuàng)建表 pseudohash隙弛。
2.2 創(chuàng)建觸發(fā)器狞山,當對表進行插入和更新時,觸發(fā) 觸發(fā)器
delimiter|
createtriggerpseudohash_crc_ins beforeinsertonpseudohashforeach row
beginset@x="hellotrigger";
setNEW.url_crc=crc32(NEW.url);
end;
|
createtriggerpseudohash_crc_upd beforeupdateonpseudohashforeach row
beginset@x="hellotrigger";
setNEW.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 查看表中數(shù)據(jù)(是進行更新操作之后的數(shù)據(jù))
2.5 更新
update pseudohash set url = 'www.163.com' where id = 1;
可以看到的是总珠,插入和更新操作后勘纯,他們的 url_crc是不同的
----------------------------------------------------------------------------
2.6 ?上面源于一個 對于url建立索引的例子,還有一種建立索引的方式: 在B+ 樹上建立一個偽索引驳遵,和真正的索引不同,它還是在B+樹 索引上進行查找堤结,但是鸭丛,使用的是 鍵的哈希值進行查找,而不是鍵本身鳞溉,這樣會加快查找
2.6.1 創(chuàng)建urls 表,注意使用的是 memory存儲引擎
CREATETABLE`urls` (
`url`varchar(255)DEFAULTNULL,
`url_crc`int(11)DEFAULT'0',
KEY`url` (`url`) USING HASH
) ENGINE=MEMORYDEFAULTCHARSET=utf8;
2.6.2 然后插入url和url_crc鼠哥,例如
insert into urls values('www.gougou.com',crc32('www.gougou.com'));
像上面的那樣,或者使用觸發(fā)器
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. 觸發(fā)器 語法
3.1CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
trigger_time是觸發(fā)程序的動作時間。它可以是BEFORE或AFTERtrigger_event指明了激活觸發(fā)程序的語句的類型贞绵。trigger_event可以是下述值之一:
·? ? ? ? ? ? INSERT:將新行插入表時激活觸發(fā)程序,例如榨崩,通過INSERT、LOAD DATA和REPLACE語句章母。
·? ? ? ? ? ? UPDATE:更改某一行時激活觸發(fā)程序,例如乳怎,通過UPDATE語句。
·? ? ? ? ? ? DELETE:從表中刪除某一行時激活觸發(fā)程序蚪缀,例如,通過DELETE和REPLACE語句询枚。
3.2 可能遇到的問題
如果你在觸發(fā)器里面對剛剛插入的數(shù)據(jù)進行了 insert/update, 會造成循環(huán)的調(diào)用.
如:
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 觸發(fā)器 與存儲過程
觸發(fā)程序不能調(diào)用將數(shù)據(jù)返回客戶端的存儲程序,也不能使用采用CALL語句的動態(tài)SQL
(允許存儲程序通過參數(shù)將數(shù)據(jù)返回觸發(fā)程序)金蜀。
而存儲過程 ?可以接受參數(shù),將結果范圍給應用程序