MySQL的觸發器:

目錄

觸發器的概念:

創建觸發器:

查看觸發器:

查看當前數據庫的所有觸發器的定義:

查看當前數據中某個觸發器的定義:

從系統information_schema的TRIGGERS表中查詢"salary_check_trigger"觸發器的信息:

刪除觸發器:

優點:

缺點:

注意:


觸發器的概念:

MySQL觸發器(?Trigger?)是一種與數據庫表關聯的特殊存儲程序,當指定事件(如INSERT、UPDATE、DELETE)發生時由數據庫?自動觸發執行?。它用于在數據變更前后執行自定義邏輯,確保數據的一致性和業務規則。

觸發器是由事件來觸發某個操作,這些事件包括INSERT、UPDATE、DELETE事件。所謂事件就是指用戶的動作或者出發某項行為。如果定義了觸發程序,當數據庫執行這些語句的時候,就相當于事件發生了,就會自動激發觸發器執行相應的操作。

創建觸發器:

CREATE TRIGGER 觸發器名稱
{BEFORE | AFTER}{INSERT | UPDATE | DELETE} ON 表名
FOR EACH ROW
觸發器執行的語句塊;

表名:表示觸發器監控的對象。

BEFORE | AFTER:表示觸發的時間。BEFORE表示在事件之前觸發,AFTER表示在事件之后觸發。

INSERT | UPDATE | DELETE:表示觸發的事件。INSERT插入記錄時觸發,UPDATE更新記錄時觸發,DELETE刪除記錄時觸發。

觸發器執行的語句塊:可以是單條SQL語句,也可以是BEGIN...END結構組成的復合語句塊。

如果使用了BEGIN...END:

DELIMITER $
CREATE TRIGGER 觸發器名
{BEFORE | AFTER} {INSERT | DELETE | UPDATE} ON 表名
FOR EACH ROW
BEGIN
執行的SQL語句
END $
DELIMITER ;

查看觸發器:

查看數據庫中已經存在的觸發器的定義、狀態和語法信息等。

查看當前數據庫的所有觸發器的定義:

SHOW TRIGGERS;

查看當前數據中某個觸發器的定義:

SHOW CREATE TRIGGER 觸發器名;

從系統information_schema的TRIGGERS表中查詢"salary_check_trigger"觸發器的信息:

SELECT * FROM information_schema.TRIGGERS;

刪除觸發器:

DROP TRIGGER [IF EXISTS] 觸發器名;

優點:

觸發器可以確保數據的完整性。可以幫助記錄操作日志。還可以用在操作數據前,對數據進行合法性檢查。

缺點:

觸發器最大的一個問題就是可讀性差。因為觸發器存儲在數據庫中,并且由事件驅動,這就意味這觸發器有可能不受應用層的控制。

相關數據的變更,可能會導致觸發器出錯。

注意:

如果在子表中定義了外鍵約束,并且外鍵制定了ON UPDATE/DELETE CASCADE/SET NULL子句,此時修改父表被引用的鍵值或者刪除附表被引用的記錄行時,也會引起子表的修改和刪除操作,此時基于子表的UPDATE和DELETE語句定義的觸發器并不會被激活。

總結:

MySQL觸發器是一種與表關聯的特殊存儲程序,在指定事件(INSERT/UPDATE/DELETE)發生時自動執行。通過CREATE TRIGGER語法創建,可設置在操作前(BEFORE)或后(AFTER)觸發,支持單條SQL或復合語句塊。觸發器能確保數據一致性、記錄操作日志和數據校驗,但存在可讀性差、不易維護的缺點。可通過SHOW TRIGGERS查看觸發器,使用DROP TRIGGER刪除。需注意外鍵約束可能影響觸發器的激活。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/92416.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/92416.shtml
英文地址,請注明出處:http://en.pswp.cn/web/92416.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基于ubuntu搭建gitlab

原文地址:基于ubuntu搭建gitlab – 無敵牛 歡迎參觀我的網站:無敵牛 – 技術/著作/典籍/分享等 之前介紹了一個使用 git openssh-server 搭建一個極簡 git 庫的方法,感興趣可以查看往期文章:手搓一個極簡遠端git庫 – 無敵牛 。…

測試GO前沿實驗室:為水系電池研究提供多維度表征解決方案

測試GO前沿實驗室:為水系電池研究提供多維度表征解決方案隨著全球能源轉型加速,水系電池因其高安全性、低成本和環境友好特性,成為下一代儲能技術的重要發展方向。測試狗前沿實驗室針對水系電池研發中的關鍵科學問題,整合先進表征…

Spring Boot 中 YAML 配置文件詳解

Spring Boot 中 YAML 配置文件詳解 在 Spring Boot 項目中,配置文件是不可或缺的一部分,用于自定義應用行為、覆蓋默認設置。除了傳統的 properties 文件,Spring Boot 對 YAML(YAML Ain’t Markup Language)格式提供了…

Milvus安裝可視化工具,attu,保姆級

安裝包鏈接:GitHub - zilliztech/attu: Web UI for Milvus Vector Databasehttps://github.com/zilliztech/attu?tabreadme-ov-file 下滑 舉例:windows:下載安裝,然后就可以連接了(安裝完打開后如果需要輸入用戶名密碼…

避免“卡脖子”!如何減少內存I/O延遲對程序的影響?

單來說,內存 IO 就像是計算機的 “數據高速公路”,負責在內存和其他設備(如硬盤、CPU 等)之間傳輸數據。它的速度和效率直接影響著計算機系統的整體性能。 你有沒有想過,當你點擊電腦上的一個應用程序,它是…

V4L2攝像頭采集 + WiFi實時傳輸實戰全流程

📖 推薦閱讀:《Yocto項目實戰教程:高效定制嵌入式Linux系統》 🎥 更多學習視頻請關注 B 站:嵌入式Jerry V4L2攝像頭采集 WiFi實時傳輸實戰全流程 1. 實戰場景概述 目標: 嵌入式設備(如RK3588/正點原子開發…

Java 之 設計模式

1.單例模式1. ??餓漢式(Eager Initialization)????核心原理??:類加載時立即創建實例,通過靜態變量直接初始化。??代碼示例??:public class Singleton {private static final Singleton INSTANCE new Sing…

[激光原理與應用-185]:光學器件 - BBO、LBO、CLBO晶體的全面比較

一、相同點非線性光學晶體屬性BBO、LBO、CLBO均為非中心對稱晶體,具備非線性光學效應,廣泛應用于激光頻率轉換(如倍頻、三倍頻、和頻、差頻)、光學參量振蕩(OPO)及電光調制等領域。寬透光范圍三者均覆蓋紫外…

Android APN加載耗時優化可行性分析

背景 根據Android系統底層機制和行業實踐,本文討論 APN 加載耗時從4.2s降至0.8s的數據合理性和技術可行性,需結合具體優化手段和硬件環境綜合分析。 以下是關鍵判斷依據及行業參考: ?? 一、APN加載耗時基準參考 未優化場景的典型耗時 首次開機或重置后:APN需從apns-con…

mysql進階-sql調優

概述優化索引在MySQL初階的課程中已經介紹了索引,我們知道InnoDB存儲引擎使?B樹作為索引默認的數據結構來組織數據,為頻繁查詢的列建?索引可以有效的提升查詢效率,那么如何利?索引編寫出?效的SQL查詢語句?以及如何分析某個查詢…

海量數據處理問題詳解

1.從a,b兩個文件各存放50億個url(每個url大小為64B),如何在內存為4G中查找a,b中相同的url 計算各文件存放大小:50億*64B 大約為320G,而內存只有4G,顯然存放不下,此時我們…

AI 記憶管理系統:工程實現設計方案

本文檔為《從“健忘”到“懂我”:構建新一代AI記憶系統》中所述理念的詳細工程實現方案。它將聚焦于技術選型、模塊設計、數據流轉和核心算法,為開發團隊提供清晰的落地指引。 1. 系統架構與技術選型 為實現分層記憶與讀寫分離的設計理念,我們…

Linux驅動學習day26天(RS485)

一、原理通過芯片將232信號轉換成485信號,485表示0和1的方法:Va - Vb 的電壓差在2~6V時表示1,Va - Vb 的電壓差在-2~-6V時表示0。這樣傳輸不容易受到干擾,并且傳輸距離長。我們需要做的事情就是發送:使能DE(driver ena…

從零構建TransformerP1-了解設計

歡迎來到啾啾的博客🐱。 記錄學習點滴。分享工作思考和實用技巧,偶爾也分享一些雜談💬。 有很多很多不足的地方,歡迎評論交流,感謝您的閱讀和評論😄。 目錄引言1 概念回顧1.1 序列任務1.1.1 將序列變成模型…

JVM 終止機制詳解:用戶線程與守護線程

用戶線程未執行完是否會阻止 JVM 終止?答案是:取決于線程類型。讓我詳細解釋: 核心規則 #mermaid-svg-bg5xpyMAeRWNGGk2 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-bg5xpyMAe…

Linux Vim 常用快捷鍵

Vim中最常用的快捷鍵,熟練掌握它們可以大大提高編輯效率。移動光標h- 左移j- 下移k- 上移l- 右移w- 移動到下一個單詞開頭b- 移動到上一個單詞開頭e- 移動到單詞末尾0- 移動到行首$- 移動到行尾gg- 移動到文件開頭G- 移動到文件末尾:n- 跳轉到第n行插入模式i- 在光標…

【Bellman負環】Cycle Finding

題目翻譯給定一個有向圖,你的任務是判斷它是否包含負環,并給出這樣一個環的示例。輸入 第一行輸入兩個整數 n 和 m:分別表示節點數和邊數。節點編號為 1, 2, ..., n。 接下來 m 行描述邊,每行有三個整數 a, b, c:表示存…

數據結構(六):樹與二叉樹

一、樹的基本概念樹的定義樹(Tree)是由 n(n ≥ 0)個節點組成的有限集合,當 n 0 時稱為空樹。非空樹中:有且僅有一個根節點(Root);其余節點可以劃分為若干個互不相交的子…

《Linux運維總結:Shell 腳本日志輸出工具》

總結:整理不易,如果對你有幫助,可否點贊關注一下? 更多詳細內容請參考:Linux運維實戰總結 一、Shell 腳本日志輸出工具 1、提供的 logger() 函數是一個非常實用的 Shell 腳本日志輸出工具,它支持帶時間戳和…

select ... for update阻塞

總結阻塞規則:當前事務持有的鎖 (來自 SELECT ... FOR UPDATE)其他事務嘗試的操作是否會被阻塞?原因排他鎖 (X Lock) 在行 R 上SELECT ... FROM ... (普通查詢)否讀快照 (MVCC),不需要鎖排他鎖 (X Lock) 在行 R 上SELECT ... FROM ... FOR UP…