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

MySQL 觸發(fā)器(TRIGGER)的具體使用

 更新時(shí)間:2024年05月23日 10:32:45   作者:霸王龍的小胳膊  
本文主要介紹了MySQL 觸發(fā)器(TRIGGER)的具體使用,包含INSERT 觸發(fā)器,UPDATE觸發(fā)器和DELETE觸發(fā)器這三種,具有一定的參考價(jià)值,感興趣的可以了解一下

1. 觸發(fā)器是什么?

  • 定義:MySQL 的觸發(fā)器和存儲過程一樣,都是嵌入到 MySQL 中的一段程序,是 MySQL 中管理數(shù)據(jù)的有力工具。通過對數(shù)據(jù)表的相關(guān)操作來觸發(fā)、激活從而實(shí)現(xiàn)執(zhí)行。比如當(dāng)對 student 表進(jìn)行操作( INSERT, DELETE 或 UPDATE)時(shí)就會激活它執(zhí)行。
  • 作用:觸發(fā)器與數(shù)據(jù)表關(guān)系密切,主要用于保護(hù)表中的數(shù)據(jù)。特別是當(dāng)有多個(gè)表具有一定的相互聯(lián)系的時(shí)候,觸發(fā)器能夠讓不同的表保持?jǐn)?shù)據(jù)的一致性、日志記錄 , 數(shù)據(jù)校驗(yàn)等操作。

2. 觸發(fā)器的優(yōu)缺點(diǎn)

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

  • 觸發(fā)器的執(zhí)行是自動的,當(dāng)對觸發(fā)器相關(guān)表的數(shù)據(jù)做出相應(yīng)的修改后立即執(zhí)行。
  • 觸發(fā)器可以實(shí)施比 FOREIGN KEY 約束、CHECK 約束更為復(fù)雜的檢查和操作。
  • 觸發(fā)器可以實(shí)現(xiàn)表數(shù)據(jù)的級聯(lián)更改,在一定程度上保證了數(shù)據(jù)的完整性

觸發(fā)器的缺點(diǎn)如下:

  • 使用觸發(fā)器實(shí)現(xiàn)的業(yè)務(wù)邏輯在出現(xiàn)問題時(shí)很難進(jìn)行定位,特別是涉及到多個(gè)觸發(fā)器的情況下,會使后期維護(hù)變得困難
  • 大量使用觸發(fā)器容易導(dǎo)致代碼結(jié)構(gòu)被打亂,增加了程序的復(fù)雜性,
  • 如果需要變動的數(shù)據(jù)量較大時(shí),觸發(fā)器的執(zhí)行效率會非常低。

3. 觸發(fā)器的類型

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

使用別名OLD和NEW來引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,這與其他的數(shù)據(jù)庫是相似的?,F(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ā)器需要注意以下幾點(diǎn):

更多操作在 INSERT 觸發(fā)器代碼內(nèi),可引用一個(gè)名為 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ā)器需要注意以下幾點(diǎn):

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

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

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

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

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

3.3 DELETE觸發(fā)器

DELETE 語句執(zhí)行之前或之后響應(yīng)的觸發(fā)器,使用 DELETE 觸發(fā)器需要注意以下幾點(diǎn):

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

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

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

  • 對于事務(wù)性表,如果觸發(fā)程序失敗,以及由此導(dǎo)致的整個(gè)語句失敗,那么該語句所執(zhí)行的所有更改將回滾;對于非事務(wù)性表,則不能執(zhí)行此類回滾,即使語句失敗,失敗之前所做的任何更改依然有效。
  • 若 BEFORE 觸發(fā)程序失敗,則 MySQL 將不執(zhí)行相應(yīng)行上的操作。
  • 若在 BEFORE 或 AFTER 觸發(fā)程序的執(zhí)行過程中出現(xiàn)錯(cuò)誤,則將導(dǎo)致調(diào)用觸發(fā)程序的整個(gè)語句失敗。
  • 僅當(dāng) 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ā)器在當(dāng)前數(shù)據(jù)庫中必須具有唯一的名稱。如果要在某個(gè)特定數(shù)據(jù)庫中創(chuàng)建,名稱前面應(yīng)該加上數(shù)據(jù)庫的名稱。

INSERT | UPDATE | DELETE

觸發(fā)事件,用于指定激活觸發(fā)器的語句的種類。

注意:三種觸發(fā)器的執(zhí)行時(shí)間如下。

  • INSERT:將新行插入表時(shí)激活觸發(fā)器。例如,INSERT 的 BEFORE 觸發(fā)器不僅能被 MySQL 的 INSERT 語句激活,也能被 LOAD DATA 語句激活。
  • DELETE: 從表中刪除某一行數(shù)據(jù)時(shí)激活觸發(fā)器,例如 DELETE 和 REPLACE 語句。
  • UPDATE:更改表中某一行數(shù)據(jù)時(shí)激活觸發(fā)器,例如 UPDATE 語句。

BEFORE | AFTER

BEFORE 和 AFTER,觸發(fā)器被觸發(fā)的時(shí)刻,表示觸發(fā)器是在激活它的語句之前或之后觸發(fā)。若希望驗(yàn)證新數(shù)據(jù)是否滿足條件,則使用 BEFORE 選項(xiàng);若希望在激活觸發(fā)器的語句執(zhí)行之后完成幾個(gè)或更多的改變,則通常使用 AFTER 選項(xiàng)。

表名

與觸發(fā)器相關(guān)聯(lián)的表名,此表必須是永久性表,不能將觸發(fā)器與臨時(shí)表或視圖關(guān)聯(lián)起來。在該表上觸發(fā)事件發(fā)生時(shí)才會激活觸發(fā)器。同一個(gè)表不能擁有兩個(gè)具有相同觸發(fā)時(shí)刻和事件的觸發(fā)器。例如,對于一張數(shù)據(jù)表,不能同時(shí)有兩個(gè) BEFORE UPDATE 觸發(fā)器,但可以有一個(gè) BEFORE UPDATE 觸發(fā)器和一個(gè) BEFORE INSERT 觸發(fā)器,或一個(gè) BEFORE UPDATE 觸發(fā)器和一個(gè) AFTER UPDATE 觸發(fā)器。

觸發(fā)器主體

觸發(fā)器動作主體,包含觸發(fā)器激活時(shí)將要執(zhí)行的 MySQL 語句。如果要執(zhí)行多個(gè)語句,可使用 BEGIN…END 復(fù)合語句結(jié)構(gòu)。

FOR EACH ROW

一般是指行級觸發(fā),對于受觸發(fā)事件影響的每一行都要激活觸發(fā)器的動作。例如,使用 INSERT 語句向某個(gè)表中插入多行數(shù)據(jù)時(shí),觸發(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)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • MySQL二進(jìn)制日志(bin_log)的作用與使用方法

    MySQL二進(jìn)制日志(bin_log)的作用與使用方法

    BinLog又稱為二進(jìn)制日志,是MySQL服務(wù)層的數(shù)據(jù)日志,MySQL所有的存儲引擎都支持BinLog,這篇文章主要給大家介紹了關(guān)于MySQL二進(jìn)制日志(bin_log)的作用與使用方法的相關(guān)資料,需要的朋友可以參考下
    2024-06-06
  • Advanced SQL Injection with MySQL

    Advanced SQL Injection with MySQL

    Advanced SQL Injection with MySQL...
    2006-12-12
  • 一臺服務(wù)器部署兩個(gè)獨(dú)立的mysql數(shù)據(jù)庫操作實(shí)例

    一臺服務(wù)器部署兩個(gè)獨(dú)立的mysql數(shù)據(jù)庫操作實(shí)例

    這篇文章主要給大家介紹了關(guān)于一臺服務(wù)器部署兩個(gè)獨(dú)立的mysql數(shù)據(jù)庫的相關(guān)資料,同一臺服務(wù)器裝兩個(gè)數(shù)據(jù)庫,可以通過虛擬化技術(shù)實(shí)現(xiàn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • Navicat自動備份MySQL數(shù)據(jù)的流程步驟

    Navicat自動備份MySQL數(shù)據(jù)的流程步驟

    對于從事IT開發(fā)的工程師,數(shù)據(jù)備份我想大家并不陌生,這件工程太重要了!對于比較重要的數(shù)據(jù),我們希望能定期備份,每天備份1次或多次,或者是每周備份1次或多次,所以本文給大家介紹了Navicat自動備份MySQL數(shù)據(jù)的流程步驟,需要的朋友可以參考下
    2024-12-12
  • mysql主從及遇到的問題解決

    mysql主從及遇到的問題解決

    本文詳細(xì)介紹了如何使用Docker配置MySQL主從復(fù)制,首先創(chuàng)建了兩個(gè)文件夾并分別配置了`my.cnf`文件,通過執(zhí)行腳本啟動容器并配置好主從關(guān)系,文中還提到了一些常見問題的解決方法,如配置路徑錯(cuò)誤導(dǎo)致的沖突和slave的change連接錯(cuò)誤
    2025-01-01
  • PhpMyAdmin 配置文件現(xiàn)在需要一個(gè)短語密碼的解決方法

    PhpMyAdmin 配置文件現(xiàn)在需要一個(gè)短語密碼的解決方法

    本文主要介紹PhpMyAdmin 配置文件現(xiàn)在需要一個(gè)短語密碼的解決方法,比較實(shí)用,希望能給大家做一個(gè)參考。
    2016-06-06
  • CentOS7離線安裝MySQL的教程詳解

    CentOS7離線安裝MySQL的教程詳解

    這篇文章主要介紹了CentOS7離線安裝MySQL的教程,在安裝之前需要我們先刪除原有的mariadb,文中也通過命令給大家介紹了,需要的朋友跟隨小編也看看吧
    2019-07-07
  • Mysql binlog的查看方法

    Mysql binlog的查看方法

    MySQL的二進(jìn)制日志可以說是MySQL最重要的日志了,本文主要介紹了Mysql binlog的查看方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-04-04
  • MySQL中數(shù)據(jù)視圖操作詳解

    MySQL中數(shù)據(jù)視圖操作詳解

    視圖是從一個(gè)或多個(gè)表(或視圖)導(dǎo)出的表。視圖一經(jīng)定義,就可以像表一樣被查詢、修改、刪除和更新。本文就來和大家講講MySQL數(shù)據(jù)視圖的一些基本操作,需要的可以參考一下
    2022-08-08
  • MySQL8.0.20單機(jī)多實(shí)例部署步驟

    MySQL8.0.20單機(jī)多實(shí)例部署步驟

    本文主要介紹了MySQL8.0.20單機(jī)多實(shí)例部署步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05

最新評論