您好,登錄后才能下訂單哦!
本文小編為大家詳細(xì)介紹“MySQL觸發(fā)器如何使用”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“MySQL觸發(fā)器如何使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。
將兩個(gè)關(guān)聯(lián)的操作步驟寫到程序里面,并且要用事務(wù)包裹起來(lái),確保兩個(gè)操作稱為一個(gè)原子操作,要么全部執(zhí)行,要么全部不執(zhí)行
創(chuàng)建一個(gè)觸發(fā)器,讓商品信息數(shù)據(jù)的插入操作自動(dòng)觸發(fā)庫(kù)存數(shù)據(jù)的插入操作
觸發(fā)器是由 事件來(lái)觸發(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)的操作。
CREATE TRIGGER 觸發(fā)器名稱
{BEFORE|AFTER} {INSERT|UPDATE|DELETE} ON 表明
FOR EACH ROW
觸發(fā)器執(zhí)行語(yǔ)句
說(shuō)明:
表名 :表示觸發(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ǔ)句塊。
DELIMITER // CREATE TRIGGER before_insert_test_tri BEFORE INSERT ON test_trigger FOR EACH ROW BEGIN INSERT INTO test_trigger_log(t_node) VALUES('before insert'); END // DELIMITER ; INSERT INTO test_trigger(t_node) VALUES('test..'); SELECT * FROM test_trigger; SELECT * FROM test_trigger_log;
DELIMITER // CREATE TRIGGER salary_check_trigger BEFORE INSERT ON emp FOR EACH ROW BEGIN DECLARE mgr_sal DOUBLE; SELECT salary INTO mgr_sal FROM emp WHERE employee_id = NEW.manager_id; IF NEW.salary > mgr_sal THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪資不得高于領(lǐng)導(dǎo)薪資'; END IF; END // DELIMITER ; DESC emp; INSERT INTO emp(employee_id,last_name,email,hire_date,job_id,salary,manager_id) VALUES(300,'test','tom@126.com',CURDATE(),'AD_VP',10000,103);
查看當(dāng)前數(shù)據(jù)庫(kù)所有觸發(fā)器的定義
mysql> SHOW TRIGGERS\G; *************************** 1. row *************************** Trigger: salary_check_trigger Event: INSERT Table: emp Statement: BEGIN DECLARE mgr_sal DOUBLE; SELECT salary INTO mgr_sal FROM emp WHERE employee_id = NEW.manager_id; IF NEW.salary > mgr_sal THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪資不得高于領(lǐng)導(dǎo)薪資'; END IF; END Timing: BEFORE Created: 2023-02-28 15:46:44.71 sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION Definer: root@% character_set_client: utf8 collation_connection: utf8_general_ci Database Collation: utf8_general_ci
查看當(dāng)前數(shù)據(jù)庫(kù)中某個(gè)觸發(fā)器的定義
SHOW CREATE TRIGGER salary_check_trigger\G;
從系統(tǒng)庫(kù)information_schema的TRIGGERS表中查詢“salary_check_trigger”觸發(fā)器的信息。
SELECT * FROM information_schema.TRIGGERS\G;
DROP TRIGGER salary_check_trigger
優(yōu)點(diǎn):
可以確保數(shù)據(jù)的完整性
可以幫助記錄操作日志
可以用在操作數(shù)據(jù)前,對(duì)數(shù)據(jù)進(jìn)行合法性檢驗(yàn)
缺點(diǎn):
可讀性差
ER salary_check_trigger
### 觸發(fā)器優(yōu)缺點(diǎn)
#### 優(yōu)點(diǎn):
- 可以確保數(shù)據(jù)的完整性
- 可以幫助記錄操作日志
- 可以用在操作數(shù)據(jù)前,對(duì)數(shù)據(jù)進(jìn)行合法性檢驗(yàn)#### 缺點(diǎn):
- 可讀性差
- 相關(guān)數(shù)據(jù)的變更,可能會(huì)導(dǎo)致觸發(fā)器錯(cuò)誤
讀到這里,這篇“MySQL觸發(fā)器如何使用”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。