溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql觸發(fā)器的概念是什么

發(fā)布時(shí)間:2022-06-14 13:55:39 來源:億速云 閱讀:170 作者:iii 欄目:MySQL數(shù)據(jù)庫(kù)

本篇內(nèi)容介紹了“mysql觸發(fā)器的概念是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

在mysql中,觸發(fā)器是存儲(chǔ)在數(shù)據(jù)庫(kù)目錄中的一組SQL語(yǔ)句,每當(dāng)與表相關(guān)聯(lián)的事件發(fā)生時(shí),即會(huì)執(zhí)行或觸發(fā)觸發(fā)器,例如插入、更新或刪除。觸發(fā)器與數(shù)據(jù)表關(guān)系密切,主要用于保護(hù)表中的數(shù)據(jù);特別是當(dāng)有多個(gè)表具有一定的相互聯(lián)系的時(shí)候,觸發(fā)器能夠讓不同的表保持?jǐn)?shù)據(jù)的一致性。在MySQL中,只有執(zhí)行INSERT、UPDATE和DELETE操作時(shí)才能激活觸發(fā)器,其它SQL語(yǔ)句則不會(huì)激活觸發(fā)器。

mysql觸發(fā)器的概念是什么

本教程操作環(huán)境:windows7系統(tǒng)、mysql8版本、Dell G3電腦。

mysql中的觸發(fā)器

在mysql中,觸發(fā)器是存儲(chǔ)在數(shù)據(jù)庫(kù)目錄中的一組SQL語(yǔ)句,每當(dāng)與表相關(guān)聯(lián)的事件發(fā)生時(shí),即會(huì)執(zhí)行或觸發(fā)觸發(fā)器,例如插入、更新或刪除。

MySQL 的觸發(fā)器和存儲(chǔ)過程一樣,都是嵌入到 MySQL 中的一段程序,是 MySQL 中管理數(shù)據(jù)的有力工具。不同的是執(zhí)行存儲(chǔ)過程要使用 CALL 語(yǔ)句來調(diào)用,而觸發(fā)器的執(zhí)行不需要使用 CALL 語(yǔ)句來調(diào)用,也不需要手工啟動(dòng),而是通過對(duì)數(shù)據(jù)表的相關(guān)操作來觸發(fā)、激活從而實(shí)現(xiàn)執(zhí)行。比如當(dāng)對(duì) student 表進(jìn)行操作(INSERT,DELETE 或 UPDATE)時(shí)就會(huì)激活它執(zhí)行。

觸發(fā)器與數(shù)據(jù)表關(guān)系密切,主要用于保護(hù)表中的數(shù)據(jù)。特別是當(dāng)有多個(gè)表具有一定的相互聯(lián)系的時(shí)候,觸發(fā)器能夠讓不同的表保持?jǐn)?shù)據(jù)的一致性。

在 MySQL 中,只有執(zhí)行 INSERT、UPDATE 和 DELETE 操作時(shí)才能激活觸發(fā)器,其它 SQL 語(yǔ)句則不會(huì)激活觸發(fā)器。

那么為什么要使用觸發(fā)器呢?比如,在實(shí)際開發(fā)項(xiàng)目時(shí),我們經(jīng)常會(huì)遇到以下情況:

  • 在學(xué)生表中添加一條關(guān)于學(xué)生的記錄時(shí),學(xué)生的總數(shù)就必須同時(shí)改變。

  • 增加一條學(xué)生記錄時(shí),需要檢查年齡是否符合范圍要求。

  • 刪除一條學(xué)生信息時(shí),需要?jiǎng)h除其成績(jī)表上的對(duì)應(yīng)記錄。

  • 刪除一條數(shù)據(jù)時(shí),需要在數(shù)據(jù)庫(kù)存檔表中保留一個(gè)備份副本。

雖然上述情況實(shí)現(xiàn)的業(yè)務(wù)邏輯不同,但是它們都需要在數(shù)據(jù)表發(fā)生更改時(shí),自動(dòng)進(jìn)行一些處理。這時(shí)就可以使用觸發(fā)器處理。例如,對(duì)于第一種情況,可以創(chuàng)建一個(gè)觸發(fā)器對(duì)象,每當(dāng)添加一條學(xué)生記錄時(shí),就執(zhí)行一次計(jì)算學(xué)生總數(shù)的操作,這樣就可以保證每次添加一條學(xué)生記錄后,學(xué)生總數(shù)和學(xué)生記錄數(shù)是一致的。

MySQL 支持的觸發(fā)器

在實(shí)際使用中,MySQL 所支持的觸發(fā)器有三種:INSERT 觸發(fā)器、UPDATE 觸發(fā)器和 DELETE 觸發(fā)器。

1) INSERT 觸發(fā)器

在 INSERT 語(yǔ)句執(zhí)行之前或之后響應(yīng)的觸發(fā)器。

使用 INSERT 觸發(fā)器需要注意以下幾點(diǎn):

  • 在 INSERT 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 NEW(不區(qū)分大小寫)的虛擬表來訪問被插入的行。

  • 在 BEFORE INSERT 觸發(fā)器中,NEW 中的值也可以被更新,即允許更改被插入的值(只要具有對(duì)應(yīng)的操作權(quán)限)。

  • 對(duì)于 AUTO_INCREMENT 列,NEW 在 INSERT 執(zhí)行之前包含的值是 0,在 INSERT 執(zhí)行之后將包含新的自動(dòng)生成值。

2) UPDATE 觸發(fā)器

在 UPDATE 語(yǔ)句執(zhí)行之前或之后響應(yīng)的觸發(fā)器。

使用 UPDATE 觸發(fā)器需要注意以下幾點(diǎn):

  • 在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 NEW(不區(qū)分大小寫)的虛擬表來訪問更新的值。

  • 在 UPDATE 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 OLD(不區(qū)分大小寫)的虛擬表來訪問 UPDATE 語(yǔ)句執(zhí)行前的值。

  • 在 BEFORE UPDATE 觸發(fā)器中,NEW 中的值可能也被更新,即允許更改將要用于 UPDATE 語(yǔ)句中的值(只要具有對(duì)應(yīng)的操作權(quán)限)。

  • OLD 中的值全部是只讀的,不能被更新。

注意:當(dāng)觸發(fā)器設(shè)計(jì)對(duì)觸發(fā)表自身的更新操作時(shí),只能使用 BEFORE 類型的觸發(fā)器,AFTER 類型的觸發(fā)器將不被允許。

3) DELETE 觸發(fā)器

在 DELETE 語(yǔ)句執(zhí)行之前或之后響應(yīng)的觸發(fā)器。

使用 DELETE 觸發(fā)器需要注意以下幾點(diǎn):

  • 在 DELETE 觸發(fā)器代碼內(nèi),可以引用一個(gè)名為 OLD(不區(qū)分大小寫)的虛擬表來訪問被刪除的行。

  • OLD 中的值全部是只讀的,不能被更新。

總體來說,觸發(fā)器使用的過程中,MySQL 會(huì)按照以下方式來處理錯(cuò)誤。

對(duì)于事務(wù)性表,如果觸發(fā)程序失敗,以及由此導(dǎo)致的整個(gè)語(yǔ)句失敗,那么該語(yǔ)句所執(zhí)行的所有更改將回滾;對(duì)于非事務(wù)性表,則不能執(zhí)行此類回滾,即使語(yǔ)句失敗,失敗之前所做的任何更改依然有效。

若 BEFORE 觸發(fā)程序失敗,則 MySQL 將不執(zhí)行相應(yīng)行上的操作。

若在 BEFORE 或 AFTER 觸發(fā)程序的執(zhí)行過程中出現(xiàn)錯(cuò)誤,則將導(dǎo)致調(diào)用觸發(fā)程序的整個(gè)語(yǔ)句失敗。

僅當(dāng) BEFORE 觸發(fā)程序和行操作均已被成功執(zhí)行,MySQL 才會(huì)執(zhí)行 AFTER 觸發(fā)程序。

“mysql觸發(fā)器的概念是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(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)容。

AI