欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談MySQL觸發(fā)器的原理以及使用

 更新時(shí)間:2023年05月19日 10:24:57   作者:智慧浩海  
這篇文章主要介紹了淺談MySQL觸發(fā)器的原理以及使用,觸發(fā)器的執(zhí)行不需要使用 CALL 語(yǔ)句來調(diào)用,也不需要手工啟動(dòng),只要一個(gè)預(yù)定義的事件發(fā)生就會(huì)被 MySQL自動(dòng)調(diào)用,需要的朋友可以參考下

MySQL 觸發(fā)器

MySQL 數(shù)據(jù)庫(kù)中觸發(fā)器是一個(gè)特殊的存儲(chǔ)過程,不同的是執(zhí)行存儲(chǔ)過程要使用 CALL 語(yǔ)句來調(diào)用,而觸發(fā)器的執(zhí)行不需要使用 CALL 語(yǔ)句來調(diào)用,也不需要手工啟動(dòng),只要一個(gè)預(yù)定義的事件發(fā)生就會(huì)被 MySQL自動(dòng)調(diào)用。

引發(fā)觸發(fā)器執(zhí)行的事件一般如下:

  • 增加一條學(xué)生記錄時(shí),會(huì)自動(dòng)檢查年齡是否符合范圍要求。
  • 每當(dāng)刪除一條學(xué)生信息時(shí),自動(dòng)刪除其成績(jī)表上的對(duì)應(yīng)記錄。
  • 每當(dāng)刪除一條數(shù)據(jù)時(shí),在數(shù)據(jù)庫(kù)存檔表中保留一個(gè)備份副本。

觸發(fā)程序的優(yōu)點(diǎn)如下:

  • 觸發(fā)程序的執(zhí)行是自動(dòng)的,當(dāng)對(duì)觸發(fā)程序相關(guān)表的數(shù)據(jù)做出相應(yīng)的修改后立即執(zhí)行。
  • 觸發(fā)程序可以通過數(shù)據(jù)庫(kù)中相關(guān)的表層疊修改另外的表。
  • 觸發(fā)程序可以實(shí)施比 FOREIGN KEY 約束、CHECK 約束更為復(fù)雜的檢查和操作。

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

在 MySQL 中,只有執(zhí)行 INSERT、UPDATE 和 DELETE 操作時(shí)才能激活觸發(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ā)程序。

到此這篇關(guān)于淺談MySQL觸發(fā)器的原理以及使用的文章就介紹到這了,更多相關(guān)MySQL觸發(fā)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql連續(xù)聚合原理與用法實(shí)例分析

    mysql連續(xù)聚合原理與用法實(shí)例分析

    這篇文章主要介紹了mysql連續(xù)聚合原理與用法,結(jié)合實(shí)例形式分析了mysql連續(xù)聚合的原理、功能、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-12-12
  • MySQL高級(jí)操作指令匯總

    MySQL高級(jí)操作指令匯總

    本文給大家?guī)淼氖荕ySQL高級(jí)操作指令代碼,羅列的很詳細(xì)并且附帶有例子,對(duì)大家的學(xué)習(xí)將會(huì)很有用,建議收藏以防丟失,需要的朋友可以參考下
    2022-01-01
  • 論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的

    論一條select語(yǔ)句在MySQL是怎樣執(zhí)行的

    本文將建立一套建立一套MySQL的知識(shí)框架,通過討論select語(yǔ)句在MySQL是怎樣執(zhí)行的來展開內(nèi)容,感興趣的小伙伴一起來看下文吧
    2021-08-08
  • MySQL中varchar(n) 中n最大取值為多少

    MySQL中varchar(n) 中n最大取值為多少

    本文主要介紹了MySQL中varchar(n) 中n最大取值為多少
    2024-08-08
  • centos7下mysqldump定時(shí)備份數(shù)據(jù)庫(kù)的方法實(shí)現(xiàn)

    centos7下mysqldump定時(shí)備份數(shù)據(jù)庫(kù)的方法實(shí)現(xiàn)

    MySQL Dump是MySQL提供的方便導(dǎo)出數(shù)據(jù)庫(kù)數(shù)據(jù)的工具,本文主要介紹了centos7下mysqldump定時(shí)備份數(shù)據(jù)庫(kù)的方法實(shí)現(xiàn),感興趣的可以了解一下
    2023-08-08
  • MySQL+Navicat安裝配置保姆級(jí)教程

    MySQL+Navicat安裝配置保姆級(jí)教程

    這篇文章主要介紹了MySQL+Navicat安裝配置教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • 深入理解where 1=1的用處

    深入理解where 1=1的用處

    本篇文章是對(duì)where 1=1的用處進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL sql_mode的使用詳解

    MySQL sql_mode的使用詳解

    這篇文章主要介紹了MySQL sql_mode的使用詳解,幫助大家更好的理解和學(xué)習(xí)使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2021-05-05
  • 一文詳解MYSQL最樸素的監(jiān)控方式

    一文詳解MYSQL最樸素的監(jiān)控方式

    對(duì)于當(dāng)前數(shù)據(jù)庫(kù)的監(jiān)控方式有很多,分為數(shù)據(jù)庫(kù)自帶、商用、開源三大類,每一種都有各自的特色,那我們今天就介紹一下完全采用mysql自有方式采集獲取監(jiān)控?cái)?shù)據(jù),在單體下達(dá)到最快速、方便、損耗最小,感興趣的同學(xué)可以借鑒閱讀
    2023-05-05
  • 聊聊MySQL中的參數(shù)

    聊聊MySQL中的參數(shù)

    這篇文章主要介紹了MySQL中的參數(shù)是什么,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-09-09

最新評(píng)論