Mysql中的觸發(fā)器定義及語(yǔ)法介紹
1.定義:
觸發(fā)器和存儲(chǔ)過(guò)程相似,都是嵌入到 MySQL 中的一段程序。觸發(fā)器是由事件來(lái)觸發(fā)某個(gè)操作。當(dāng)數(shù)據(jù)庫(kù)執(zhí)行這些事件時(shí),就會(huì)激活觸發(fā)器來(lái)執(zhí)行相應(yīng)的操作。這些事件稱為觸發(fā)條件,在MySQL中,有UPDATE,INSERT,和DELETE。
- 在MySQL中,目前只有UPDATE,INSERT,和DELETE這三種操作,才會(huì)觸發(fā)觸發(fā)器,其他操作都不支持觸發(fā)器。這和Oracle中的觸發(fā)器有很大的區(qū)別,要注意區(qū)分。
- 觸發(fā)器的每個(gè)表每次事件,都只允許一個(gè)觸發(fā)器。因此,每個(gè)表最多值允許有6個(gè)觸發(fā)器。如果一個(gè)表有兩個(gè)事件,INSERT和DELETE,那么就要分別創(chuàng)建一個(gè)觸發(fā)器。
- 只有表才支持觸發(fā)器,視圖和臨時(shí)表不支持。
2.語(yǔ)法:
CREATE TRIGGER TRIGGER_NAME BEFORE/AFTER UPDATE/INSERT/DELETE ON TABLE_NAME FOR EACH ROW #觸發(fā)器主體 [BEGIN] SQL操作 [END];
- 創(chuàng)建觸發(fā)器:和創(chuàng)建存儲(chǔ)過(guò)程是一樣,用的都是CREATE 語(yǔ)句,但要注意,這里沒有 OR REPLACE。
- TRIGGER_NAME:觸發(fā)器名稱。在MySQL中,要保證每個(gè)表中的觸發(fā)器是唯一的,每一個(gè)數(shù)據(jù)庫(kù)內(nèi)的觸發(fā)器可以不唯一,這就說(shuō)明了一個(gè)數(shù)據(jù)庫(kù)內(nèi)的兩個(gè)表可以有相同的觸發(fā)器。這種行為在其他的數(shù)據(jù)庫(kù)內(nèi)是不被允許的。但是為了格式上的規(guī)范,還是要盡可能的保證TRIGGER_NAME的唯一性。
- BEFORE/AFTER:觸發(fā)器被觸發(fā)的時(shí)刻。你如果希望觸發(fā)器在觸發(fā)事件之前發(fā)生,就使用BEFORE,如果希望在觸發(fā)事件之后發(fā)生,就使用AFTER。
- UPDATE/INSERT/DELETE:觸發(fā)事件,觸發(fā)條件。在MySQL中,只有這三種DDL操作支持觸發(fā)器,其他操作都不被允許。
- FOR EACH ROW:受觸發(fā)事件影響的每一行都要激活觸發(fā)器的動(dòng)作。這里指的是行級(jí)觸發(fā),在MySQL里,F(xiàn)OE EACH ROW不可省略,不支持語(yǔ)句級(jí)觸發(fā)。
- 觸發(fā)器主體:既可以是單獨(dú)的一條SQL語(yǔ)句,也可以是由BEGIN...END組成的復(fù)雜結(jié)構(gòu)塊。
# 創(chuàng)建一個(gè)觸發(fā)器T1,在對(duì)表customer做插入操作時(shí),就會(huì)觸發(fā)T1,之后會(huì)在日志表note中插入一條數(shù)據(jù) CREATE TRIGGER T1 AFTER INSERT ON customer FOR EACH ROW # 觸發(fā)器主體 INSERT INTO note(日期,目標(biāo),操作) VALUES(NOW(),'customer','insert');
3.刪除觸發(fā)器
和刪除表和存儲(chǔ)過(guò)程類似,都是使用DROP語(yǔ)句來(lái)刪除觸發(fā)器。
#刪除觸發(fā)器T1 DROP TRIGGER IF EXISTS T1;
觸發(fā)器不能夠更新和修改,想要修改一個(gè)觸發(fā)器的內(nèi)容,只能先將觸發(fā)器刪除,在創(chuàng)建一個(gè)新的觸發(fā)器。
4.查詢觸發(fā)器
#在已知數(shù)據(jù)庫(kù)內(nèi),查詢觸發(fā)器 SHOW TRIGGERS; SELECT * FROM information_schema.TRIGGERS WHERE TRIGGER_NAME = '觸發(fā)器名' #查詢所有的觸發(fā)器 SELECT * FROM information_schema.TRIGGERS(WHERE TRIGGER_SCHEMA = '數(shù)據(jù)庫(kù)名')
5.觸發(fā)器類型OLD和NEW的使用
觸發(fā)器在DDL操作之前或者之后觸發(fā),總會(huì)對(duì)目標(biāo)表做出一定的改動(dòng),有時(shí)我們需要知道目標(biāo)表改變前后的值,這就用到了OLD和NEW的用法。
顧名思義,OLD就是改變之前的值,是UPDATE之前或者是要被DELETE或者已經(jīng)被DELETE的值。
而NEW,則是UPDATE之后的新值,即將INSERT或者已經(jīng)INSERT的值。
具體實(shí)例:
#創(chuàng)建customer表 CREATE TABLE `customer` (`CUST_ID` int(11) NOT NULL AUTO_INCREMENT, `CUST_NAME` varchar(10) NOT NULL, `CUST_TEL` varchar(10) DEFAULT NULL, PRIMARY KEY (`CUST_ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; #向表中插入數(shù)據(jù) #創(chuàng)建一個(gè)update觸發(fā)器 CREATE TRIGGER T2 AFTER UPDATE ON customer FOR EACH ROW #old和new的使用方法:old.columnname/new.columnname(列名) #將更新前后的值,賦值給兩個(gè)變量 SELECT OLD.CUST_ID,NEW.CUST_ID INTO @OLD_ID,@NEW_ID; #觸發(fā)觸發(fā)器T2 UPDATE customer SET CUST_ID = '10000' WHERE CUST_NAME = 'AAA'; #查詢OLD和NEW SELECT @OLD_ID,@NEW_ID;
到此這篇關(guān)于Mysql中的觸發(fā)器的文章就介紹到這了,更多相關(guān)mysql觸發(fā)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
linux二進(jìn)制通用包安裝mysql5.6.20教程
這篇文章主要為大家詳細(xì)介紹了linux二進(jìn)制通用包安裝mysql5.6.20的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01MySQL用戶和數(shù)據(jù)權(quán)限管理詳解
這篇文章主要為大家詳細(xì)介紹了MySQL數(shù)據(jù)庫(kù)管理中的用戶和數(shù)據(jù)權(quán)限管理,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)MySQL有一定幫助,需要的可以參考一下2022-08-08詳解Mysql中explain執(zhí)行計(jì)劃信息中字段
Extra是EXPLAIN輸出中另外一個(gè)很重要的列,該列顯示MySQL在查詢過(guò)程中的一些詳細(xì)信息,MySQL查詢優(yōu)化器執(zhí)行查詢的過(guò)程中對(duì)查詢計(jì)劃的重要補(bǔ)充信息,這篇文章主要介紹了Mysql中explain執(zhí)行計(jì)劃信息中字段詳解,需要的朋友可以參考下2023-08-08MySql數(shù)據(jù)庫(kù)分布式存儲(chǔ)配置實(shí)操步驟
這篇文章主要為大家介紹了MySql數(shù)據(jù)庫(kù)分布式存儲(chǔ)配置實(shí)操步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07