MySQL的觸發(fā)器全解析(創(chuàng)建、查看觸發(fā)器)
觸發(fā)器的概念:
MySQL觸發(fā)器(Trigger)是一種與數(shù)據(jù)庫(kù)表關(guān)聯(lián)的特殊存儲(chǔ)程序,當(dāng)指定事件(如INSERT、UPDATE、DELETE)發(fā)生時(shí)由數(shù)據(jù)庫(kù)自動(dòng)觸發(fā)執(zhí)行。它用于在數(shù)據(jù)變更前后執(zhí)行自定義邏輯,確保數(shù)據(jù)的一致性和業(yè)務(wù)規(guī)則。
觸發(fā)器是由事件來觸發(fā)某個(gè)操作,這些事件包括INSERT、UPDATE、DELETE事件。所謂事件就是指用戶的動(dòng)作或者出發(fā)某項(xiàng)行為。如果定義了觸發(fā)程序,當(dāng)數(shù)據(jù)庫(kù)執(zhí)行這些語(yǔ)句的時(shí)候,就相當(dāng)于事件發(fā)生了,就會(huì)自動(dòng)激發(fā)觸發(fā)器執(zhí)行相應(yīng)的操作。
創(chuàng)建觸發(fā)器:
CREATE TRIGGER 觸發(fā)器名稱 {BEFORE | AFTER}{INSERT | UPDATE | DELETE} ON 表名 FOR EACH ROW 觸發(fā)器執(zhí)行的語(yǔ)句塊;
表名:表示觸發(fā)器監(jiān)控的對(duì)象。
BEFORE | AFTER:表示觸發(fā)的時(shí)間。BEFORE表示在事件之前觸發(fā),AFTER表示在事件之后觸發(fā)。
INSERT | UPDATE | DELETE:表示觸發(fā)的事件。INSERT插入記錄時(shí)觸發(fā),UPDATE更新記錄時(shí)觸發(fā),DELETE刪除記錄時(shí)觸發(fā)。
觸發(fā)器執(zhí)行的語(yǔ)句塊:可以是單條SQL語(yǔ)句,也可以是BEGIN...END結(jié)構(gòu)組成的復(fù)合語(yǔ)句塊。
如果使用了BEGIN...END:
DELIMITER $ CREATE TRIGGER 觸發(fā)器名 {BEFORE | AFTER} {INSERT | DELETE | UPDATE} ON 表名 FOR EACH ROW BEGIN 執(zhí)行的SQL語(yǔ)句 END $ DELIMITER ;
查看觸發(fā)器:
查看數(shù)據(jù)庫(kù)中已經(jīng)存在的觸發(fā)器的定義、狀態(tài)和語(yǔ)法信息等。
查看當(dāng)前數(shù)據(jù)庫(kù)的所有觸發(fā)器的定義:
SHOW TRIGGERS;
查看當(dāng)前數(shù)據(jù)中某個(gè)觸發(fā)器的定義:
SHOW CREATE TRIGGER 觸發(fā)器名;
從系統(tǒng)information_schema的TRIGGERS表中查詢"salary_check_trigger"觸發(fā)器的信息:
SELECT * FROM information_schema.TRIGGERS;
刪除觸發(fā)器:
DROP TRIGGER [IF EXISTS] 觸發(fā)器名;
優(yōu)點(diǎn):
觸發(fā)器可以確保數(shù)據(jù)的完整性??梢詭椭涗洸僮魅罩?。還可以用在操作數(shù)據(jù)前,對(duì)數(shù)據(jù)進(jìn)行合法性檢查。
缺點(diǎn):
觸發(fā)器最大的一個(gè)問題就是可讀性差。因?yàn)橛|發(fā)器存儲(chǔ)在數(shù)據(jù)庫(kù)中,并且由事件驅(qū)動(dòng),這就意味這觸發(fā)器有可能不受應(yīng)用層的控制。
相關(guān)數(shù)據(jù)的變更,可能會(huì)導(dǎo)致觸發(fā)器出錯(cuò)。
注意:
如果在子表中定義了外鍵約束,并且外鍵制定了ON UPDATE/DELETE CASCADE/SET NULL子句,此時(shí)修改父表被引用的鍵值或者刪除附表被引用的記錄行時(shí),也會(huì)引起子表的修改和刪除操作,此時(shí)基于子表的UPDATE和DELETE語(yǔ)句定義的觸發(fā)器并不會(huì)被激活。
總結(jié):
MySQL觸發(fā)器是一種與表關(guān)聯(lián)的特殊存儲(chǔ)程序,在指定事件(INSERT/UPDATE/DELETE)發(fā)生時(shí)自動(dòng)執(zhí)行。通過CREATE TRIGGER語(yǔ)法創(chuàng)建,可設(shè)置在操作前(BEFORE)或后(AFTER)觸發(fā),支持單條SQL或復(fù)合語(yǔ)句塊。觸發(fā)器能確保數(shù)據(jù)一致性、記錄操作日志和數(shù)據(jù)校驗(yàn),但存在可讀性差、不易維護(hù)的缺點(diǎn)??赏ㄟ^SHOW TRIGGERS查看觸發(fā)器,使用DROP TRIGGER刪除。需注意外鍵約束可能影響觸發(fā)器的激活。
到此這篇關(guān)于MySQL的觸發(fā)器的文章就介紹到這了,更多相關(guān)mysql觸發(fā)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL中的觸發(fā)器trigger用法解析
- Mysql中的觸發(fā)器定義及語(yǔ)法介紹
- 淺談MySQL中的觸發(fā)器
- Mysql中的觸發(fā)器簡(jiǎn)單介紹及使用案例
- MySQL與SQL的觸發(fā)器的不同寫法
- mysql觸發(fā)器實(shí)時(shí)檢測(cè)一條語(yǔ)句進(jìn)行備份刪除思路詳解
- MySQL觸發(fā)器基本用法詳解【創(chuàng)建、查看、刪除等】
- MySQL如何創(chuàng)建觸發(fā)器(CREATE TRIGGER)
- mysql 觸發(fā)器創(chuàng)建與使用方法示例
- mysql觸發(fā)器之創(chuàng)建多個(gè)觸發(fā)器操作實(shí)例分析
相關(guān)文章
MySQL如何快速創(chuàng)建800w條測(cè)試數(shù)據(jù)表
這篇文章主要介紹了MySQL如何快速創(chuàng)建800w條測(cè)試數(shù)據(jù)表,下面文章圍繞MySQL創(chuàng)建測(cè)試數(shù)據(jù)表的相關(guān)資料展開詳細(xì)內(nèi)容,具有一的的參考價(jià)值,需要的小伙伴可以參考一下2022-03-03Mybatis中的動(dòng)態(tài)SQL語(yǔ)句解析
這篇文章主要介紹了Mybatis中的動(dòng)態(tài)SQL語(yǔ)句解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11mysql問題之slow log中出現(xiàn)大量的binlog dump記錄的解決方法
今天在查看mysql中發(fā)現(xiàn)比較慢,然后我使用了slow log,發(fā)現(xiàn)出現(xiàn)了大量的binlog dump記錄,下面我來給大家整理一下這個(gè)問題的解決辦法2013-09-09Windows服務(wù)器下MySql數(shù)據(jù)庫(kù)單向主從備份詳細(xì)實(shí)現(xiàn)步驟分享
將主服務(wù)器中的MySql數(shù)據(jù)庫(kù)同步到從服務(wù)器中,使得對(duì)主服務(wù)器的操作可以即時(shí)更新到從服務(wù)器,避免主服務(wù)器因環(huán)境或者網(wǎng)絡(luò)異常一時(shí)無法使用,達(dá)到備份效果,這篇文章整理的確實(shí)挺詳細(xì)的2012-05-05