亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL觸發(fā)器的使用

瀏覽:126日期:2023-10-02 16:05:42

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

從上述描述可以看到,觸發(fā)器可以簡化應(yīng)用程序的邏輯并且可以提升性能,這是因為使用觸發(fā)器減少了應(yīng)用程序和服務(wù)端的交互次數(shù)。同時,觸發(fā)器有助于完成自動更新歸一化和統(tǒng)計數(shù)據(jù)。例如,我們可以使用觸發(fā)器自動統(tǒng)計交易訂單總金額,訂單數(shù)及平均客單價。 然而,MySQL 的觸發(fā)器的應(yīng)用場合也十分有限,如果你使用過其他數(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 ROWBEGIN 執(zhí)行語句列表;END

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

DELIMITER $$CREATE TRIGGER user_create_log AFTER INSERT ON t_users FOR EACH ROWBEGINDECLARE log_info VARCHAR(40)character set utf8;DECLARE description VARCHAR(20) character set utf8;#后面發(fā)現(xiàn)中文字符編碼出現(xiàn)亂碼,這里設(shè)置字符集SET description = ' is created';SET log_info = CONCAT(NEW.user_name, description); #函數(shù)CONCAT可以將字符串連接INSERT INTO logs(log) values(log_info);END $$DELIMITER ; 觸發(fā)器可能導(dǎo)致服務(wù)端實際執(zhí)行的工作不可預(yù)測,一個簡單的語句可能導(dǎo)致服務(wù)端做大量不可見的工作。例如,如果一個觸發(fā)器更新了 一個相關(guān)的表,可能導(dǎo)致受影響的行數(shù)加倍。 觸發(fā)器難以調(diào)試,并且一旦引入了觸發(fā)器,很難分析性能瓶頸。 觸發(fā)器會導(dǎo)致潛在的鎖等待和死鎖。如果觸發(fā)器失敗了,源查詢也會失敗。如果沒有意識到觸發(fā)器的存在,這類玩呢提很難發(fā)現(xiàn)。

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

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

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

結(jié)語:

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

以上就是MySQL觸發(fā)器的使用的詳細(xì)內(nèi)容,更多關(guān)于MySQL觸發(fā)器的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 97国产大学生情侣11在线视频 | 午夜精品在线免费观看 | 亚洲视频网址 | 久久精品亚洲精品国产欧美 | 国产1024精品视频专区免费 | 日韩高清成人 | 国产亚洲自拍一区 | 91最新在线 | 成人午夜精品久久久久久久小说 | 成人性生免费视频 | 亚洲国产精品久久久久 | 日本高清免费一本视频在线观看 | 欧美亚洲国产另类 | 色婷婷啪啪 | 日本欧美片 | 国产成人一区二区三区精品久久 | 看一级毛片 | 41sao.can在线观看国产 | 久热精品视频在线观看99小说 | 国产资源在线观看 | 中文字幕有码热在线视频 | 日本不卡高清中文字幕免费 | 国产麻豆视频在线观看 | 黄网站在线免费 | 狠狠操影院| 人人狠狠综合久久亚洲88 | 日本午夜一级特黄毛片 | 国产农村1级毛片 | 久久www成人看片 | 片黄免费 | 国产精品久久久久久久久久妇女 | 99久久精品国产片 | 国产精品_国产精品_国产精品 | 丁香月婷婷| 在线播放精品 | 国产精品嫩草视频永久网址 | 成人在线视频网站 | 欧美高清在线不卡免费观看 | 亚洲国产情侣偷自在线二页 | 久久中文字幕制服丝袜美腿 | 欧美色视频日本片高清在线观看 |