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

MySQL觸發(fā)器的使用

 更新時間:2021年05月24日 09:46:34   作者:島上碼農(nóng)  
觸發(fā)器用于在 MySQL 執(zhí)行插入、更新或刪除語句時,自動觸發(fā)執(zhí)行其他SQL代碼。本文講解觸發(fā)器的正確使用方式

觸發(fā)器可以在執(zhí)行語句前或執(zhí)行后觸發(fā)其他 SQL 代碼運行。觸發(fā)器可以讀取觸發(fā)語句改變了哪些數(shù)據(jù),但是沒有返回值。因此可以使用觸發(fā)器加強業(yè)務邏輯的約束而不需要在應用程序?qū)憣拇a。

從上述描述可以看到,觸發(fā)器可以簡化應用程序的邏輯并且可以提升性能,這是因為使用觸發(fā)器減少了應用程序和服務端的交互次數(shù)。同時,觸發(fā)器有助于完成自動更新歸一化和統(tǒng)計數(shù)據(jù)。例如,我們可以使用觸發(fā)器自動統(tǒng)計交易訂單總金額,訂單數(shù)及平均客單價。 然而,MySQL 的觸發(fā)器的應用場合也十分有限,如果你使用過其他數(shù)據(jù)庫產(chǎn)品的觸發(fā)器,不要以為 MySQL 也能實現(xiàn)相同的功能,例如:

  • 每個數(shù)據(jù)表的單一事件只能有一個觸發(fā)器,也就是說對于 AFTER INSERT 這樣的事件來說,不能同時有超過1個的觸發(fā)器。
  • MySQL 只支持行級別的觸發(fā)器,也就是只能按 FOR EACH ROW 這種方式使用觸發(fā)而不是整個 SQL 語句,這對于大量數(shù)據(jù)的操作而言會比較低效。MySQL 的觸發(fā)器只能按下面的形式編寫:
CREATE TRIGGER 觸發(fā)器名 BEFORE|AFTER 觸發(fā)事件
ON 表名 FOR EACH ROW
BEGIN
    執(zhí)行語句列表;
END

執(zhí)行語句列表支持單條或多條語句,下面是一個多條語句的示例:

DELIMITER $$
CREATE TRIGGER user_create_log AFTER INSERT ON t_users FOR EACH ROW
BEGIN
DECLARE log_info VARCHAR(40)character set utf8;
DECLARE description VARCHAR(20) character set utf8;#后面發(fā)現(xiàn)中文字符編碼出現(xiàn)亂碼,這里設置字符集
SET description = " is created";
SET log_info = CONCAT(NEW.user_name, description);     #函數(shù)CONCAT可以將字符串連接
INSERT INTO logs(log) values(log_info);
END $$

DELIMITER ;
  • 觸發(fā)器可能導致服務端實際執(zhí)行的工作不可預測,一個簡單的語句可能導致服務端做大量不可見的工作。例如,如果一個觸發(fā)器更新了 一個相關的表,可能導致受影響的行數(shù)加倍。
  • 觸發(fā)器難以調(diào)試,并且一旦引入了觸發(fā)器,很難分析性能瓶頸。
  • 觸發(fā)器會導致潛在的鎖等待和死鎖。如果觸發(fā)器失敗了,源查詢也會失敗。如果沒有意識到觸發(fā)器的存在,這類玩呢提很難發(fā)現(xiàn)。

大多數(shù)限制中,最大的限制是 FOR EACH ROW 的設計,這有時候?qū)е掠|發(fā)器沒法用于維護統(tǒng)計和緩存表,這是因為這可能很慢。使用觸發(fā)器的主要理由是相比定時同步更新,觸發(fā)器可以一致保持數(shù)據(jù)的一致性。 觸發(fā)器也沒法保證原子性。例如,更新 MyISAM 數(shù)據(jù)表的觸發(fā)器在源 SQL 語句出錯后,無法回滾。而且,觸發(fā)器自身也可能都只錯誤。如果我們使用了 AFTER UPDATE 基于 MyISAM 數(shù)據(jù)表去更新另一個表。如果觸發(fā)器有個導致第二張表操作失敗的錯誤,那對于第一張表的操作不會回滾。

InnoDB 的觸發(fā)器相關的操作,包括源語句都在同一個事務中,因此是滿足原子性的。然而,如果使用InnoDB 的觸發(fā)器去與另一張表校驗數(shù)據(jù)一致性的時候,這個時候如果不小心的話可能導致不正確的結果。例如,假設需要使用觸發(fā)器模擬外鍵,可以使用 BEFORE INSERT觸發(fā)器驗證另一張表是否存在對應的記錄,但是如果在觸發(fā)器讀取另一張表數(shù)據(jù)的時候不使用 SELECT FOR UPDATE的話,則由于并發(fā)性性問題可能導致錯誤的結果。 雖然觸發(fā)器有些缺陷,但是這并不意味著不能用。相反,觸發(fā)器本身也是有用的,尤其是對于約束,系統(tǒng)維護任務和保持統(tǒng)計數(shù)據(jù)保持最新。

也可以使用觸發(fā)器記錄數(shù)據(jù)行的變化。這樣即便是離線手動操作數(shù)據(jù)庫的記錄(如修復錯誤數(shù)據(jù))也能夠被記錄下來。但是,需要注意的是對于往其他自增主鍵表插入數(shù)據(jù)時要小心,這對于復制性的語句表現(xiàn)會有問題,因為自增值對于兩個相同的副本值并不同。

結語:

觸發(fā)器在有限的場合能夠發(fā)揮其優(yōu)勢,比如統(tǒng)計數(shù)據(jù)、數(shù)據(jù)表變更日志等。但是也會有一些缺陷,比如大數(shù)據(jù)量的更新由于逐行觸發(fā),會降低效率。還有就是,MyISAM 引擎無法保障原子性。因此,要根據(jù)應用場景是否要是有觸發(fā)器。

以上就是MySQL觸發(fā)器的使用的詳細內(nèi)容,更多關于MySQL觸發(fā)器的資料請關注腳本之家其它相關文章!

相關文章

  • MySQL中的IF語句使用小結

    MySQL中的IF語句使用小結

    在MySQL數(shù)據(jù)庫中,IF 語句是一種常見的條件控制語句,本文介紹了 MySQL 中 IF 語句的基本用法以及實際應用場景,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • mysql 5.7.17 安裝配置方法圖文教程(CentOS7)

    mysql 5.7.17 安裝配置方法圖文教程(CentOS7)

    這篇文章主要為大家詳細介紹了CentOS7下mysql 5.7.17 安裝配置方法圖文教程,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 線上MYSQL同步報錯故障處理方法總結(必看篇)

    線上MYSQL同步報錯故障處理方法總結(必看篇)

    下面小編就為大家?guī)硪黄€上MYSQL同步報錯故障處理方法總結(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • Linux系統(tǒng)下實現(xiàn)遠程連接MySQL數(shù)據(jù)庫的方法教程

    Linux系統(tǒng)下實現(xiàn)遠程連接MySQL數(shù)據(jù)庫的方法教程

    MySQL默認root用戶只能本地訪問,不能遠程連接管理mysql數(shù)據(jù)庫,Linux如何開啟mysql遠程連接?下面這篇文章主要給大家介紹了在Linux系統(tǒng)下實現(xiàn)遠程連接MySQL數(shù)據(jù)庫的方法教程,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-06-06
  • Mysql prepare預處理的具體使用

    Mysql prepare預處理的具體使用

    本文主要介紹了Mysql prepare預處理,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Mysql的longblob字段插入數(shù)據(jù)問題解決

    Mysql的longblob字段插入數(shù)據(jù)問題解決

    在使用mysql的過程中,有個問題就是mysql的優(yōu)化,mysql中l(wèi)ongblob字段在5.5版本中默認的為1M,需要解決問題的朋友可以參考下
    2014-01-01
  • dmysql自己封裝的mysql庫

    dmysql自己封裝的mysql庫

    dmysql自己封裝的mysql庫...
    2007-07-07
  • Mysql中禁用與啟動觸發(fā)器教程【推薦】

    Mysql中禁用與啟動觸發(fā)器教程【推薦】

    在使用MYSQL過程中,經(jīng)常會使用到觸發(fā)器,但是有時使用不當會造成一些麻煩。下面小編給大家?guī)砹薓ysql中禁用與啟動觸發(fā)器教程,感興趣的朋友一起看看吧
    2018-08-08
  • mysql如何在線修改主從復制選項

    mysql如何在線修改主從復制選項

    這篇文章主要介紹了mysql如何在線修改主從復制選項,幫助大家更好的理解和學習mysql,感興趣的朋友可以了解下
    2020-08-08
  • 一文了解Mysql分區(qū)的使用

    一文了解Mysql分區(qū)的使用

    分區(qū)允許根據(jù)可以設置為任意大小的規(guī)則,跨文件系統(tǒng)分配單個表的多個部分,本文主要介紹了Mysql分區(qū)的使用,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06

最新評論