日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 触发器学习

發布時間:2025/5/22 数据库 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 触发器学习 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mysql 觸發器學習

1. 一個簡單的例子

1.1. 創建表:

? ?create table t(s1 integer);

1.2. 觸發器:

delimiter | create?trigger?t_trigger before insert?on?t? for?each row begin?set?@x = "hello trigger"; ???????set?NEW.s1 = 55; end; |

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. 可以看到結果:

? ??

1.7可以使用?SHOW TRIGGERS; 查看新建的觸發器

?

2. url查詢哈希值的維護 觸發器

? ? 2.1 創建表 pseudohash。

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 查看表中數據(是進行更新操作之后的數據)

? ? 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'));

? ? ? ? 像上面的那樣,或者使用觸發器

? ? ? ? 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 触发器学习的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。