1. 一個(gè)簡(jiǎn)單的例子 1.1. 創(chuàng)建表: create table t(s1 integer); 1.2. 觸發(fā)器:
1.3. 如果觸發(fā)器創(chuàng)建錯(cuò)誤,,可能只能刪除了,,至少我試過(guò)不能replace drop trigger t_trigger; 1.4. 當(dāng)執(zhí)行insert 時(shí): insert into t values(1); 1.5. 會(huì)執(zhí)行觸發(fā)器t_trigger select @x,t.* from t; 1.6. 可以看到結(jié)果:
1.7可以使用 SHOW TRIGGERS; 查看新建的觸發(fā)器 2. url查詢哈希值的維護(hù) 觸發(fā)器 2.1 創(chuàng)建表 pseudohash。 2.2 創(chuàng)建觸發(fā)器,,當(dāng)對(duì)表進(jìn)行插入和更新時(shí),,觸發(fā) 觸發(fā)器 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ù)(是進(jìn)行更新操作之后的數(shù)據(jù)) 2.5 更新 update pseudohash set url = 'www.163.com' where id = 1; 可以看到的是,插入和更新操作后,,他們的 url_crc是不同的 ---------------------------------------------------------------------------- 2.6 上面源于一個(gè) 對(duì)于url建立索引的例子,,還有一種建立索引的方式: 在B+ 樹上建立一個(gè)偽索引,和真正的索引不同,,它還是在B+樹 索引上進(jìn)行查找,,但是,使用的是 鍵的哈希值進(jìn)行查找,,而不是鍵本身,,這樣會(huì)加快查找 2.6.1 創(chuàng)建urls 表,注意使用的是 memory存儲(chǔ)引擎
CREATE TABLE `urls` ( 2.6.2 然后插入url和url_crc,,例如 insert into urls values('www.gougou.com',crc32('www.gougou.com')); 像上面的那樣,,或者使用觸發(fā)器 2.6.3 然后查詢的時(shí)候使用 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個(gè)查詢結(jié)果當(dāng)然是一樣的,但是速度上hash的快很多 3. 觸發(fā)器 語(yǔ)法 3.1 CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW trigger_stmt
trigger_time是觸發(fā)程序的動(dòng)作時(shí)間,。它可以是BEFORE或AFTERtrigger_event指明了激活觸發(fā)程序的語(yǔ)句的類型,。trigger_event可以是下述值之一: · INSERT:將新行插入表時(shí)激活觸發(fā)程序,例如,,通過(guò)INSERT,、LOAD DATA和REPLACE語(yǔ)句。
· UPDATE:更改某一行時(shí)激活觸發(fā)程序,,例如,,通過(guò)UPDATE語(yǔ)句。
· DELETE:從表中刪除某一行時(shí)激活觸發(fā)程序,,例如,,通過(guò)DELETE和REPLACE語(yǔ)句,。
3.2 可能遇到的問題
如果你在觸發(fā)器里面對(duì)剛剛插入的數(shù)據(jù)進(jìn)行了 insert/update, 會(huì)造成循環(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 應(yīng)該使用set: create trigger test before update on test for each row set NEW.updateTime = NOW(); END 3.3 觸發(fā)器 與存儲(chǔ)過(guò)程 觸發(fā)程序不能調(diào)用將數(shù)據(jù)返回客戶端的存儲(chǔ)程序,也不能使用采用CALL語(yǔ)句的動(dòng)態(tài)SQL (允許存儲(chǔ)程序通過(guò)參數(shù)將數(shù)據(jù)返回觸發(fā)程序),。
而存儲(chǔ)過(guò)程 可以接受參數(shù),,將結(jié)果范圍給應(yīng)用程序
|
|