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

mysql觸發(fā)器之創(chuàng)建使用觸發(fā)器簡單示例

 更新時間:2019年12月17日 08:39:09   作者:luyaran  
這篇文章主要介紹了mysql觸發(fā)器之創(chuàng)建使用觸發(fā)器,結(jié)合實(shí)例形式分析了mysql創(chuàng)建、查看、調(diào)用觸發(fā)器的相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了mysql觸發(fā)器之創(chuàng)建使用觸發(fā)器。分享給大家供大家參考,具體如下:

我們可以可以使用CREATE TRIGGER語句創(chuàng)建一個新的觸發(fā)器,來看下具體的語法:

CREATE TRIGGER trigger_name trigger_time trigger_event
 ON table_name
 FOR EACH ROW
 BEGIN
 ...
 END;

然后我們來詳細(xì)看下上述sql的具體含義:

  • 將觸發(fā)器名稱放在CREATE TRIGGER語句之后。觸發(fā)器名稱應(yīng)遵循命名約定[trigger time]_[table name]_[trigger event],例如before_employees_update。
  • 觸發(fā)激活時間可以在之前或之后。必須指定定義觸發(fā)器的激活時間。如果要在更改之前處理操作,則使用BEFORE關(guān)鍵字,如果在更改后需要處理操作,則使用AFTER關(guān)鍵字。
  • 觸發(fā)事件可以是INSERT,UPDATE或DELETE。此事件導(dǎo)致觸發(fā)器被調(diào)用。 觸發(fā)器只能由一個事件調(diào)用。要定義由多個事件調(diào)用的觸發(fā)器,必須定義多個觸發(fā)器,每個事件一個觸發(fā)器。
  • 觸發(fā)器必須與特定表關(guān)聯(lián)。沒有表觸發(fā)器將不存在,所以必須在ON關(guān)鍵字之后指定表名。
  • 將SQL語句放在BEGIN和END塊之間。這是定義觸發(fā)器邏輯的位置。

大概了解了之后,我們就來嘗試創(chuàng)建觸發(fā)器來記錄employees表中行數(shù)據(jù)的更改情況,先來看下這個表的結(jié)構(gòu):

mysql> DESC employees;
+----------------+--------------+------+-----+---------+-------+
| Field     | Type     | Null | Key | Default | Extra |
+----------------+--------------+------+-----+---------+-------+
| employeeNumber | int(11)   | NO  | PRI | NULL  |    |
| lastName    | varchar(50) | NO  |   | NULL  |    |
| firstName   | varchar(50) | NO  |   | NULL  |    |
| extension   | varchar(10) | NO  |   | NULL  |    |
| email     | varchar(100) | NO  |   | NULL  |    |
| officeCode   | varchar(10) | NO  | MUL | NULL  |    |
| reportsTo   | int(11)   | YES | MUL | NULL  |    |
| jobTitle    | varchar(50) | NO  |   | NULL  |    |
+----------------+--------------+------+-----+---------+-------+
8 rows in set

我們再來創(chuàng)建一個名為employees audit的新表,用來保存employees表中數(shù)據(jù)的更改:

CREATE TABLE employees_audit (
  id INT AUTO_INCREMENT PRIMARY KEY,
  employeeNumber INT NOT NULL,
  lastname VARCHAR(50) NOT NULL,
  changedat DATETIME DEFAULT NULL,
  action VARCHAR(50) DEFAULT NULL
);

再來創(chuàng)建一個BEFORE UPDATE觸發(fā)器,該觸發(fā)器在對employees表中的行記錄更改之前被調(diào)用:

DELIMITER $$
CREATE TRIGGER before_employee_update 
  BEFORE UPDATE ON employees
  FOR EACH ROW 
BEGIN
  INSERT INTO employees_audit
  SET action = 'update',
   employeeNumber = OLD.employeeNumber,
    lastname = OLD.lastname,
    changedat = NOW(); 
END$$
DELIMITER ;

在上述觸發(fā)器的主體中,我們使用OLD關(guān)鍵字來訪問受觸發(fā)器影響的行的employeeNumber和lastname列。我們要注意的是,在為insert定義的觸發(fā)器中,可以僅使用NEW關(guān)鍵字。不能使用OLD關(guān)鍵字。但是,在為DELETE定義的觸發(fā)器中,沒有新行,因此您只能使用OLD關(guān)鍵字。在update觸發(fā)器中,OLD是指更新前的行,而NEW是更新后的行。

然后,我們可以使用SHOW TRIGGERS語句,來查看數(shù)據(jù)庫中的觸發(fā)器:

mysql> SHOW TRIGGERS;
+------------------------+--------+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+------------------------+-----------------------------------------------------------------------------------+----------------+----------------------+----------------------+--------------------+
| Trigger        | Event | Table   | Statement                                                                               | Timing | Created        | sql_mode                                     | Definer    | character_set_client | collation_connection | Database Collation |
+------------------------+--------+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+------------------------+-----------------------------------------------------------------------------------+----------------+----------------------+----------------------+--------------------+
| before_employee_update | UPDATE | employees | BEGIN
  INSERT INTO employees_audit
  SET action = 'update',
   employeeNumber = OLD.employeeNumber,
    lastname = OLD.lastname,
    changedat = NOW();
END | BEFORE | 2017-08-02 22:06:36.40 | ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION | root@localhost | utf8         | utf8_general_ci   | utf8_general_ci  |
+------------------------+--------+-----------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+------------------------+-----------------------------------------------------------------------------------+----------------+----------------------+----------------------+--------------------+
1 row in set

完事我們就來更新employees表以檢查觸發(fā)器是否被調(diào)用:

UPDATE employees 
SET 
  lastName = 'Maxsu'
WHERE
  employeeNumber = 1056;

可以使用以下查詢來查詢employees_audit表,用以檢查觸發(fā)器是否被UPDATE語句調(diào)用:

mysql> SELECT * FROM employees_audit;
+----+----------------+----------+---------------------+--------+
| id | employeeNumber | lastname | changedat      | action |
+----+----------------+----------+---------------------+--------+
| 1 |      1056 | Hill   | 2017-08-02 22:15:51 | update |
+----+----------------+----------+---------------------+--------+
1 row in set

如上面輸出結(jié)果所示,觸發(fā)器被真正調(diào)用,并在employees_audit表中插入一個新行。

好啦,本次記錄就到這里了。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總

希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。

相關(guān)文章

  • MySQL中使用正則表達(dá)式詳情

    MySQL中使用正則表達(dá)式詳情

    這牌你文章主要給大家分享的是MySQL中使用正則表達(dá)式詳情,MySQL中支持正則表達(dá)式匹配,在復(fù)雜的過濾條件中,可以考慮使用正則表達(dá)式。使用正則表達(dá)式需要掌握一些正則表達(dá)式的語法和指令,下面來看看文章的詳細(xì)內(nèi)容介紹吧,希望對你有所幫助
    2021-11-11
  • MySQL 通過索引優(yōu)化含ORDER BY的語句

    MySQL 通過索引優(yōu)化含ORDER BY的語句

    合理的建立索引能夠加速數(shù)據(jù)讀取效率,不合理的建立索引反而會拖慢數(shù)據(jù)庫的響應(yīng)速度。
    2010-03-03
  • MySQL索引總結(jié)(Index?Type)

    MySQL索引總結(jié)(Index?Type)

    本文主要介紹了MySQL索引總結(jié)(Index?Type),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • CentOS 8 安裝 MySql并設(shè)置允許遠(yuǎn)程連接的方法

    CentOS 8 安裝 MySql并設(shè)置允許遠(yuǎn)程連接的方法

    這篇文章主要介紹了CentOS 8 安裝 MySql并設(shè)置允許遠(yuǎn)程連接的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • MySql日期查詢語句詳解

    MySql日期查詢語句詳解

    在mysql中對時間日期操作的函數(shù)有很多,有時我們就希望直接通過sql查詢出指定日期的數(shù)據(jù)
    2013-11-11
  • 在IDEA的maven項(xiàng)目中連接并使用MySQL8.0的方法教程

    在IDEA的maven項(xiàng)目中連接并使用MySQL8.0的方法教程

    這篇文章主要介紹了如何在IDEA的maven項(xiàng)目中連接并使用MySQL8.0,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Mysql 行級鎖的使用及死鎖的預(yù)防方案

    Mysql 行級鎖的使用及死鎖的預(yù)防方案

    mysql的InnoDB,支持事務(wù)和行級鎖,可以使用行鎖來處理用戶提現(xiàn)等業(yè)務(wù)。使用mysql鎖的時候有時候會出現(xiàn)死鎖,要做好死鎖的預(yù)防。這篇文章通過實(shí)例應(yīng)用給大家講解
    2016-12-12
  • MySQL查詢優(yōu)化的5個實(shí)用技巧

    MySQL查詢優(yōu)化的5個實(shí)用技巧

    這篇文章主要介紹了MySQL查詢優(yōu)化的5個實(shí)用技巧,從數(shù)據(jù)類型、字符集、子查詢等角度分析了MySQL查詢優(yōu)化的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-12-12
  • MySQL處理重復(fù)數(shù)據(jù)的學(xué)習(xí)筆記

    MySQL處理重復(fù)數(shù)據(jù)的學(xué)習(xí)筆記

    在本篇文章里小編給大家分享的是一篇關(guān)于MySQL處理重復(fù)數(shù)據(jù)的學(xué)習(xí)筆記,需要的朋友們可以參考下。
    2020-03-03
  • MySQL性能分析及explain的使用說明

    MySQL性能分析及explain的使用說明

    本文我們主要介紹了MySQL性能分析以及explain的使用,包括:組合索引、慢查詢分析、MYISAM和INNODB的鎖定、MYSQL的事務(wù)配置項(xiàng)等,希望能夠?qū)δ兴鶐椭?/div> 2011-08-08

最新評論