MySQL 觸發(fā)器(TRIGGER)的具體使用
1. 觸發(fā)器是什么?
- 定義:MySQL 的觸發(fā)器和存儲過程一樣,都是嵌入到 MySQL 中的一段程序,是 MySQL 中管理數(shù)據(jù)的有力工具。通過對數(shù)據(jù)表的相關(guān)操作來觸發(fā)、激活從而實(shí)現(xiàn)執(zhí)行。比如當(dāng)對 student 表進(jìn)行操作( INSERT, DELETE 或 UPDATE)時(shí)就會激活它執(zhí)行。
- 作用:觸發(fā)器與數(shù)據(jù)表關(guān)系密切,主要用于保護(hù)表中的數(shù)據(jù)。特別是當(dāng)有多個(gè)表具有一定的相互聯(lián)系的時(shí)候,觸發(fā)器能夠讓不同的表保持?jǐn)?shù)據(jù)的一致性、日志記錄 , 數(shù)據(jù)校驗(yàn)等操作。
2. 觸發(fā)器的優(yōu)缺點(diǎn)
觸發(fā)器的優(yōu)點(diǎn)如下:
- 觸發(fā)器的執(zhí)行是自動的,當(dāng)對觸發(fā)器相關(guān)表的數(shù)據(jù)做出相應(yīng)的修改后立即執(zhí)行。
- 觸發(fā)器可以實(shí)施比 FOREIGN KEY 約束、CHECK 約束更為復(fù)雜的檢查和操作。
- 觸發(fā)器可以實(shí)現(xiàn)表數(shù)據(jù)的級聯(lián)更改,在一定程度上保證了數(shù)據(jù)的完整性。
觸發(fā)器的缺點(diǎn)如下:
- 使用觸發(fā)器實(shí)現(xiàn)的業(yè)務(wù)邏輯在出現(xiàn)問題時(shí)很難進(jìn)行定位,特別是涉及到多個(gè)觸發(fā)器的情況下,會使后期維護(hù)變得困難。
- 大量使用觸發(fā)器容易導(dǎo)致代碼結(jié)構(gòu)被打亂,增加了程序的復(fù)雜性,
- 如果需要變動的數(shù)據(jù)量較大時(shí),觸發(fā)器的執(zhí)行效率會非常低。
3. 觸發(fā)器的類型
在實(shí)際使用中, MySQL 所支持的觸發(fā)器有三種: INSERT 觸發(fā)器
、 UPDATE 觸發(fā)器
和 DELETE 觸發(fā)器
。
使用別名OLD和NEW來引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,這與其他的數(shù)據(jù)庫是相似的?,F(xiàn)在觸發(fā)器還只支持行級觸發(fā),不支持語句級觸發(fā)。
觸發(fā)器類型 | NEW 和 OLD |
---|---|
INSERT 型觸發(fā)器 | NEW 表示將要或者已經(jīng)新增的數(shù)據(jù) |
UPDATE 型觸發(fā)器 | OLD 表示修改之前的數(shù)據(jù) , NEW 表示將要或已經(jīng)修改后的數(shù)據(jù) |
DELETE 型觸發(fā)器 | OLD 表示將要或者已經(jīng)刪除的數(shù)據(jù) |
3.1 INSERT觸發(fā)器
在 INSERT 語句執(zhí)行之前或之后響應(yīng)的觸發(fā)器,使用 INSERT 觸發(fā)器需要注意以下幾點(diǎn):
更多操作在 INSERT 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 NEW(不區(qū)分大小寫)的虛擬表來訪問被插入的行。
在 BEFORE INSERT 觸發(fā)器中, NEW 中的值也可以被更新,即允許更改被插入的值(只要具有對應(yīng)的操作權(quán)限)。
對于 AUTO_INCREMENT 列, NEW 在 INSERT 執(zhí)行之前包含的值是 0,在 INSERT 執(zhí)行之后將包含新的自動生成值。
3.2 UPDATE觸發(fā)器
在 UPDATE 語句執(zhí)行之前或之后響應(yīng)的觸發(fā)器,使用 UPDATE 觸發(fā)器需要注意以下幾點(diǎn):
在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 NEW(不區(qū)分大小寫)的虛擬表來訪問更新的值。
在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 OLD(不區(qū)分大小寫)的虛擬表來訪問 UPDATE 語句執(zhí)行前的值。
在 BEFORE UPDATE 觸發(fā)器中,NEW 中的值可能也被更新,即允許更改將要用于 UPDATE 語句中的值(只要具有對應(yīng)的操作權(quán)限)。
OLD 中的值全部是只讀的,不能被更新。
注意:當(dāng)觸發(fā)器設(shè)計(jì)對觸發(fā)表自身的更新操作時(shí),只能使用 BEFORE 類型的觸發(fā)器,AFTER 類型的觸發(fā)器將不被允許。
3.3 DELETE觸發(fā)器
DELETE 語句執(zhí)行之前或之后響應(yīng)的觸發(fā)器,使用 DELETE 觸發(fā)器需要注意以下幾點(diǎn):
在 DELETE 觸發(fā)器代碼內(nèi),可以引用一個(gè)名為 OLD(不區(qū)分大小寫)的虛擬表來訪問被刪除的行。
OLD 中的值全部是只讀的,不能被更新。
總體來說,觸發(fā)器使用的過程中,MySQL 會按照以下方式來處理錯(cuò)誤。
- 對于事務(wù)性表,如果觸發(fā)程序失敗,以及由此導(dǎo)致的整個(gè)語句失敗,那么該語句所執(zhí)行的所有更改將回滾;對于非事務(wù)性表,則不能執(zhí)行此類回滾,即使語句失敗,失敗之前所做的任何更改依然有效。
- 若 BEFORE 觸發(fā)程序失敗,則 MySQL 將不執(zhí)行相應(yīng)行上的操作。
- 若在 BEFORE 或 AFTER 觸發(fā)程序的執(zhí)行過程中出現(xiàn)錯(cuò)誤,則將導(dǎo)致調(diào)用觸發(fā)程序的整個(gè)語句失敗。
- 僅當(dāng) BEFORE 觸發(fā)程序和行操作均已被成功執(zhí)行,MySQL 才會執(zhí)行 AFTER 觸發(fā)程序。
4. 觸發(fā)器的相關(guān)語法
4.1 創(chuàng)建觸發(fā)器
在 MySQL 5.7 中,可以使用 CREATE TRIGGER 語句創(chuàng)建觸發(fā)器,語法格式如下:
CREATE <觸發(fā)器名> < BEFORE | AFTER > <INSERT | UPDATE | DELETE > ON <表名> FOR EACH Row<觸發(fā)器主體>
觸發(fā)器名
觸發(fā)器的名稱,觸發(fā)器在當(dāng)前數(shù)據(jù)庫中必須具有唯一的名稱。如果要在某個(gè)特定數(shù)據(jù)庫中創(chuàng)建,名稱前面應(yīng)該加上數(shù)據(jù)庫的名稱。
INSERT | UPDATE | DELETE
觸發(fā)事件,用于指定激活觸發(fā)器的語句的種類。
注意:三種觸發(fā)器的執(zhí)行時(shí)間如下。
- INSERT:將新行插入表時(shí)激活觸發(fā)器。例如,INSERT 的 BEFORE 觸發(fā)器不僅能被 MySQL 的 INSERT 語句激活,也能被 LOAD DATA 語句激活。
- DELETE: 從表中刪除某一行數(shù)據(jù)時(shí)激活觸發(fā)器,例如 DELETE 和 REPLACE 語句。
- UPDATE:更改表中某一行數(shù)據(jù)時(shí)激活觸發(fā)器,例如 UPDATE 語句。
BEFORE | AFTER
BEFORE 和 AFTER,觸發(fā)器被觸發(fā)的時(shí)刻,表示觸發(fā)器是在激活它的語句之前或之后觸發(fā)。若希望驗(yàn)證新數(shù)據(jù)是否滿足條件,則使用 BEFORE 選項(xiàng);若希望在激活觸發(fā)器的語句執(zhí)行之后完成幾個(gè)或更多的改變,則通常使用 AFTER 選項(xiàng)。
表名
與觸發(fā)器相關(guān)聯(lián)的表名,此表必須是永久性表,不能將觸發(fā)器與臨時(shí)表或視圖關(guān)聯(lián)起來。在該表上觸發(fā)事件發(fā)生時(shí)才會激活觸發(fā)器。同一個(gè)表不能擁有兩個(gè)具有相同觸發(fā)時(shí)刻和事件的觸發(fā)器。例如,對于一張數(shù)據(jù)表,不能同時(shí)有兩個(gè) BEFORE UPDATE 觸發(fā)器,但可以有一個(gè) BEFORE UPDATE 觸發(fā)器和一個(gè) BEFORE INSERT 觸發(fā)器,或一個(gè) BEFORE UPDATE 觸發(fā)器和一個(gè) AFTER UPDATE 觸發(fā)器。
觸發(fā)器主體
觸發(fā)器動作主體,包含觸發(fā)器激活時(shí)將要執(zhí)行的 MySQL 語句。如果要執(zhí)行多個(gè)語句,可使用 BEGIN…END 復(fù)合語句結(jié)構(gòu)。
FOR EACH ROW
一般是指行級觸發(fā),對于受觸發(fā)事件影響的每一行都要激活觸發(fā)器的動作。例如,使用 INSERT 語句向某個(gè)表中插入多行數(shù)據(jù)時(shí),觸發(fā)器會對每一行數(shù)據(jù)的插入都執(zhí)行相應(yīng)的觸發(fā)器動作。
案例1:插入數(shù)據(jù)觸發(fā)器
create trigger tb_user_insert_trigger after insert on tb_user for each row begin insert into user_logs(id, operation, operate_time, operate_id, operate_params) VALUES (null, 'insert', now(), new.id, concat('插入的數(shù)據(jù)內(nèi)容為:id=',new.id,',name=',new.name, ', phone=', NEW.phone, ', email=', NEW.email, ',profession=', NEW.profession)); end;
案例2:修改觸發(fā)器
create trigger tb_user_update_trigger after update on tb_user for each row begin insert into user_logs(id, operation, operate_time, operate_id, operate_params) VALUES (null, 'update', now(), new.id,concat('更新之前的數(shù)據(jù): id=',old.id,',name=',old.name, ', phone=', old.phone, ', email=', old.email, ', profession=', old.profession,' | 更新之后的數(shù)據(jù): id=',new.id,',name=',new.name, ', phone=',NEW.phone, ', email=', NEW.email, ', profession=', NEW.profession)); end;
案例3:刪除觸發(fā)器
create trigger tb_user_delete_trigger after delete on tb_user for each row begin insert into user_logs(id, operation, operate_time, operate_id, operate_params) VALUES (null, 'delete', now(), old.id,concat('刪除之前的數(shù)據(jù): id=',old.id,',name=',old.name, ', phone=', old.phone, ', email=', old.email, ', profession=', old.profession)); end;
4.2 查看觸發(fā)器
在 MySQL 中,可以通過 SHOW TRIGGERS 語句來查看觸發(fā)器的基本信息,語法格式如下:
SHOW TRIGGERS;
在 MySQL 中,所有觸發(fā)器的信息都存在 information_schema 數(shù)據(jù)庫的 triggers 表中,可以通過查詢命令 SELECT 來查看,具體的語法如下:
SELECT * FROM information_schema.triggers WHERE trigger_name= '觸發(fā)器名';
查看所有的觸發(fā)器:
SELECT * FROM information_schema.triggers
4.3 刪除觸發(fā)器
使用 DROP TRIGGER 語句可以刪除 MySQL 中已經(jīng)定義的觸發(fā)器。
DROP TRIGGER [ IF EXISTS ] [數(shù)據(jù)庫名] <觸發(fā)器名>
到此這篇關(guān)于MySQL 觸發(fā)器(TRIGGER)的具體使用的文章就介紹到這了,更多相關(guān)MySQL 觸發(fā)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL觸發(fā)器Trigger加載及目前局限性
- 一文教你如何使用MySQL觸發(fā)器
- 淺談MySQL觸發(fā)器的原理以及使用
- MySQL存儲函數(shù)以及觸發(fā)器詳解
- MySQL中的觸發(fā)器trigger用法解析
- MySQL如何創(chuàng)建觸發(fā)器(CREATE TRIGGER)
- Mysql觸發(fā)器字段雙向更新方式
- mysql觸發(fā)器中監(jiān)控字段的改變方式
- mysql觸發(fā)器同步表的數(shù)據(jù)方式
- MySQL觸發(fā)器實(shí)現(xiàn)兩表數(shù)據(jù)同步的代碼詳解
- MySQL使用觸發(fā)器實(shí)現(xiàn)數(shù)據(jù)自動更新的應(yīng)用實(shí)例
- 從零開始MySQL觸發(fā)器實(shí)戰(zhàn)攻略
相關(guān)文章
MySQL二進(jìn)制日志(bin_log)的作用與使用方法
BinLog又稱為二進(jìn)制日志,是MySQL服務(wù)層的數(shù)據(jù)日志,MySQL所有的存儲引擎都支持BinLog,這篇文章主要給大家介紹了關(guān)于MySQL二進(jìn)制日志(bin_log)的作用與使用方法的相關(guān)資料,需要的朋友可以參考下2024-06-06Advanced SQL Injection with MySQL
Advanced SQL Injection with MySQL...2006-12-12一臺服務(wù)器部署兩個(gè)獨(dú)立的mysql數(shù)據(jù)庫操作實(shí)例
這篇文章主要給大家介紹了關(guān)于一臺服務(wù)器部署兩個(gè)獨(dú)立的mysql數(shù)據(jù)庫的相關(guān)資料,同一臺服務(wù)器裝兩個(gè)數(shù)據(jù)庫,可以通過虛擬化技術(shù)實(shí)現(xiàn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03Navicat自動備份MySQL數(shù)據(jù)的流程步驟
對于從事IT開發(fā)的工程師,數(shù)據(jù)備份我想大家并不陌生,這件工程太重要了!對于比較重要的數(shù)據(jù),我們希望能定期備份,每天備份1次或多次,或者是每周備份1次或多次,所以本文給大家介紹了Navicat自動備份MySQL數(shù)據(jù)的流程步驟,需要的朋友可以參考下2024-12-12PhpMyAdmin 配置文件現(xiàn)在需要一個(gè)短語密碼的解決方法
本文主要介紹PhpMyAdmin 配置文件現(xiàn)在需要一個(gè)短語密碼的解決方法,比較實(shí)用,希望能給大家做一個(gè)參考。2016-06-06