MySQL 觸發(fā)器(TRIGGER)的具體使用
1. 觸發(fā)器是什么?
- 定義:MySQL 的觸發(fā)器和存儲過程一樣,都是嵌入到 MySQL 中的一段程序,是 MySQL 中管理數(shù)據(jù)的有力工具。通過對數(shù)據(jù)表的相關(guān)操作來觸發(fā)、激活從而實現(xiàn)執(zhí)行。比如當對 student 表進行操作( INSERT, DELETE 或 UPDATE)時就會激活它執(zhí)行。
- 作用:觸發(fā)器與數(shù)據(jù)表關(guān)系密切,主要用于保護表中的數(shù)據(jù)。特別是當有多個表具有一定的相互聯(lián)系的時候,觸發(fā)器能夠讓不同的表保持數(shù)據(jù)的一致性、日志記錄 , 數(shù)據(jù)校驗等操作。
2. 觸發(fā)器的優(yōu)缺點
觸發(fā)器的優(yōu)點如下:
- 觸發(fā)器的執(zhí)行是自動的,當對觸發(fā)器相關(guān)表的數(shù)據(jù)做出相應(yīng)的修改后立即執(zhí)行。
- 觸發(fā)器可以實施比 FOREIGN KEY 約束、CHECK 約束更為復雜的檢查和操作。
- 觸發(fā)器可以實現(xiàn)表數(shù)據(jù)的級聯(lián)更改,在一定程度上保證了數(shù)據(jù)的完整性。
觸發(fā)器的缺點如下:
- 使用觸發(fā)器實現(xiàn)的業(yè)務(wù)邏輯在出現(xiàn)問題時很難進行定位,特別是涉及到多個觸發(fā)器的情況下,會使后期維護變得困難。
- 大量使用觸發(fā)器容易導致代碼結(jié)構(gòu)被打亂,增加了程序的復雜性,
- 如果需要變動的數(shù)據(jù)量較大時,觸發(fā)器的執(zhí)行效率會非常低。
3. 觸發(fā)器的類型
在實際使用中, MySQL 所支持的觸發(fā)器有三種: INSERT 觸發(fā)器
、 UPDATE 觸發(fā)器
和 DELETE 觸發(fā)器
。
使用別名OLD和NEW來引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,這與其他的數(shù)據(jù)庫是相似的。現(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ā)器需要注意以下幾點:
更多操作在 INSERT 觸發(fā)器代碼內(nèi),可引用一個名為 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ā)器需要注意以下幾點:
在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個名為 NEW(不區(qū)分大小寫)的虛擬表來訪問更新的值。
在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個名為 OLD(不區(qū)分大小寫)的虛擬表來訪問 UPDATE 語句執(zhí)行前的值。
在 BEFORE UPDATE 觸發(fā)器中,NEW 中的值可能也被更新,即允許更改將要用于 UPDATE 語句中的值(只要具有對應(yīng)的操作權(quán)限)。
OLD 中的值全部是只讀的,不能被更新。
注意:當觸發(fā)器設(shè)計對觸發(fā)表自身的更新操作時,只能使用 BEFORE 類型的觸發(fā)器,AFTER 類型的觸發(fā)器將不被允許。
3.3 DELETE觸發(fā)器
DELETE 語句執(zhí)行之前或之后響應(yīng)的觸發(fā)器,使用 DELETE 觸發(fā)器需要注意以下幾點:
在 DELETE 觸發(fā)器代碼內(nèi),可以引用一個名為 OLD(不區(qū)分大小寫)的虛擬表來訪問被刪除的行。
OLD 中的值全部是只讀的,不能被更新。
總體來說,觸發(fā)器使用的過程中,MySQL 會按照以下方式來處理錯誤。
- 對于事務(wù)性表,如果觸發(fā)程序失敗,以及由此導致的整個語句失敗,那么該語句所執(zhí)行的所有更改將回滾;對于非事務(wù)性表,則不能執(zhí)行此類回滾,即使語句失敗,失敗之前所做的任何更改依然有效。
- 若 BEFORE 觸發(fā)程序失敗,則 MySQL 將不執(zhí)行相應(yīng)行上的操作。
- 若在 BEFORE 或 AFTER 觸發(fā)程序的執(zhí)行過程中出現(xiàn)錯誤,則將導致調(diào)用觸發(fā)程序的整個語句失敗。
- 僅當 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ā)器在當前數(shù)據(jù)庫中必須具有唯一的名稱。如果要在某個特定數(shù)據(jù)庫中創(chuàng)建,名稱前面應(yīng)該加上數(shù)據(jù)庫的名稱。
INSERT | UPDATE | DELETE
觸發(fā)事件,用于指定激活觸發(fā)器的語句的種類。
注意:三種觸發(fā)器的執(zhí)行時間如下。
- INSERT:將新行插入表時激活觸發(fā)器。例如,INSERT 的 BEFORE 觸發(fā)器不僅能被 MySQL 的 INSERT 語句激活,也能被 LOAD DATA 語句激活。
- DELETE: 從表中刪除某一行數(shù)據(jù)時激活觸發(fā)器,例如 DELETE 和 REPLACE 語句。
- UPDATE:更改表中某一行數(shù)據(jù)時激活觸發(fā)器,例如 UPDATE 語句。
BEFORE | AFTER
BEFORE 和 AFTER,觸發(fā)器被觸發(fā)的時刻,表示觸發(fā)器是在激活它的語句之前或之后觸發(fā)。若希望驗證新數(shù)據(jù)是否滿足條件,則使用 BEFORE 選項;若希望在激活觸發(fā)器的語句執(zhí)行之后完成幾個或更多的改變,則通常使用 AFTER 選項。
表名
與觸發(fā)器相關(guān)聯(lián)的表名,此表必須是永久性表,不能將觸發(fā)器與臨時表或視圖關(guān)聯(lián)起來。在該表上觸發(fā)事件發(fā)生時才會激活觸發(fā)器。同一個表不能擁有兩個具有相同觸發(fā)時刻和事件的觸發(fā)器。例如,對于一張數(shù)據(jù)表,不能同時有兩個 BEFORE UPDATE 觸發(fā)器,但可以有一個 BEFORE UPDATE 觸發(fā)器和一個 BEFORE INSERT 觸發(fā)器,或一個 BEFORE UPDATE 觸發(fā)器和一個 AFTER UPDATE 觸發(fā)器。
觸發(fā)器主體
觸發(fā)器動作主體,包含觸發(fā)器激活時將要執(zhí)行的 MySQL 語句。如果要執(zhí)行多個語句,可使用 BEGIN…END 復合語句結(jié)構(gòu)。
FOR EACH ROW
一般是指行級觸發(fā),對于受觸發(fā)事件影響的每一行都要激活觸發(fā)器的動作。例如,使用 INSERT 語句向某個表中插入多行數(shù)據(jù)時,觸發(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ā)器實現(xiàn)兩表數(shù)據(jù)同步的代碼詳解
- MySQL使用觸發(fā)器實現(xiàn)數(shù)據(jù)自動更新的應(yīng)用實例
- 從零開始MySQL觸發(fā)器實戰(zhàn)攻略
相關(guān)文章
Advanced SQL Injection with MySQL
Advanced SQL Injection with MySQL...2006-12-12一臺服務(wù)器部署兩個獨立的mysql數(shù)據(jù)庫操作實例
這篇文章主要給大家介紹了關(guān)于一臺服務(wù)器部署兩個獨立的mysql數(shù)據(jù)庫的相關(guān)資料,同一臺服務(wù)器裝兩個數(shù)據(jù)庫,可以通過虛擬化技術(shù)實現(xiàn),文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-03-03Navicat自動備份MySQL數(shù)據(jù)的流程步驟
對于從事IT開發(fā)的工程師,數(shù)據(jù)備份我想大家并不陌生,這件工程太重要了!對于比較重要的數(shù)據(jù),我們希望能定期備份,每天備份1次或多次,或者是每周備份1次或多次,所以本文給大家介紹了Navicat自動備份MySQL數(shù)據(jù)的流程步驟,需要的朋友可以參考下2024-12-12PhpMyAdmin 配置文件現(xiàn)在需要一個短語密碼的解決方法
本文主要介紹PhpMyAdmin 配置文件現(xiàn)在需要一個短語密碼的解決方法,比較實用,希望能給大家做一個參考。2016-06-06