濮阳杆衣贸易有限公司

主頁 > 知識庫 > mysql觸發(fā)器簡介、創(chuàng)建觸發(fā)器及使用限制分析

mysql觸發(fā)器簡介、創(chuàng)建觸發(fā)器及使用限制分析

熱門標(biāo)簽:銷售語音電話機(jī)器人 安徽ai電話電銷機(jī)器人有效果嗎 萊西市地圖標(biāo)注 外呼系統(tǒng)電銷受騙 走過哪個省地圖標(biāo)注 巫師三血與酒地圖標(biāo)注 常州網(wǎng)絡(luò)外呼系統(tǒng)開發(fā) 在哪里申請400電話 400電話申請信用卡

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

簡介

SQL觸發(fā)器是存儲在數(shù)據(jù)庫目錄中的一組SQL語句。每當(dāng)與表相關(guān)聯(lián)的事件發(fā)生時,即會執(zhí)行或觸發(fā)SQL觸發(fā)器,例如插入,更新或刪除。SQL觸發(fā)器也可以當(dāng)做是一種特殊類型的存儲過程。 它是特別的,因為它不像直接像存儲過程那樣調(diào)用。 觸發(fā)器和存儲過程之間的主要區(qū)別在于,當(dāng)對表執(zhí)行數(shù)據(jù)修改事件時,會自動調(diào)用觸發(fā)器,而存儲過程必須要明確地調(diào)用。

完事我們來看下SQL觸發(fā)器的優(yōu)點:

  • SQL觸發(fā)器提供了檢查數(shù)據(jù)完整性的替代方法。
  • SQL觸發(fā)器可以捕獲數(shù)據(jù)庫層中業(yè)務(wù)邏輯中的錯誤。
  • SQL觸發(fā)器提供了運行計劃任務(wù)的另一種方法。通過使用SQL觸發(fā)器,您不必等待運行計劃的任務(wù),因為在對表中的數(shù)據(jù)進(jìn)行更改之前或之后自動調(diào)用觸發(fā)器。
  • SQL觸發(fā)器對于審核表中數(shù)據(jù)的更改非常有用。

再來看下它的缺點:

  • SQL觸發(fā)器只能提供擴(kuò)展驗證,并且無法替換所有驗證。一些簡單的驗證必須在應(yīng)用層完成。 例如,您可以使用JavaScript或服務(wù)器端使用服務(wù)器端腳本語言(如JSP,PHP,ASP.NET,Perl等)來驗證客戶端的用戶輸入。
  • 從客戶端應(yīng)用程序調(diào)用和執(zhí)行SQL觸發(fā)器不可見,因此很難弄清數(shù)據(jù)庫層中發(fā)生的情況。
  • SQL觸發(fā)器可能會增加數(shù)據(jù)庫服務(wù)器的開銷。

既然觸發(fā)器都是一種特殊的存儲過程了,那么我們在它們中間該如何取舍呢?在下只是建議下,如果我們無法使用存儲過程完成工作時,可以考慮使用下SQL觸發(fā)器。

創(chuàng)建觸發(fā)器

在MySQL中,觸發(fā)器是一組SQL語句,當(dāng)對相關(guān)聯(lián)的表上的數(shù)據(jù)進(jìn)行更改時,會自動調(diào)用該語句。 觸發(fā)器可以被定義為在insert,update或delete語句更改數(shù)據(jù)之前或之后調(diào)用。在MySQL5.7.2版本之前,每個表最多可以定義六個觸發(fā)器。我們來看下它們的簡單介紹:

  • BEFORE INSERT - 在數(shù)據(jù)插入表之前被激活觸發(fā)器。
  • AFTER INSERT - 在將數(shù)據(jù)插入表之后激活觸發(fā)器。
  • BEFORE UPDATE - 在表中的數(shù)據(jù)更新之前激活觸發(fā)器。
  • AFTER UPDATE - 在表中的數(shù)據(jù)更新之后激活觸發(fā)器。
  • BEFORE DELETE - 在從表中刪除數(shù)據(jù)之前激活觸發(fā)器。
  • AFTER DELETE - 從表中刪除數(shù)據(jù)之后激活觸發(fā)器。

但是,從MySQL 5.7.2+版本開始,可以為相同的觸發(fā)事件和動作時間定義多個觸發(fā)器。當(dāng)使用不使用INSERT,DELETE或UPDATE語句更改表中數(shù)據(jù)的語句時,不會調(diào)用與表關(guān)聯(lián)的觸發(fā)器。 例如,truncate語句刪除表的所有數(shù)據(jù),但不調(diào)用與該表相關(guān)聯(lián)的觸發(fā)器。但是,有些語句使用了后臺的INSERT語句,如REPLACE語句或LOAD DATA語句。如果使用這些語句,則調(diào)用與表關(guān)聯(lián)的相應(yīng)觸發(fā)器。所以我們必須要為與表相關(guān)聯(lián)的每個觸發(fā)器使用唯一的名稱??梢詾椴煌谋矶x相同的觸發(fā)器名稱,這是一個很好的做法。我們來看下定義觸發(fā)器的語法結(jié)構(gòu):

(BEFORE | AFTER)_tableName_(INSERT| UPDATE | DELETE)

例如,before_order_update是更新orders表中的行數(shù)據(jù)之前調(diào)用的觸發(fā)器。我們再來看一種定義方式:

tablename_(BEFORE | AFTER)_(INSERT| UPDATE | DELETE)

例如,order_before_update與上述before_order_update觸發(fā)器相同。

mysql會在在數(shù)據(jù)目錄中存儲觸發(fā)器,例如:/data/luyaran/,并使用名為tablename.TRG和triggername.TRN的文件:

  • tablename.TRG文件將觸發(fā)器映射到相應(yīng)的表。
  • triggername.TRN文件包含觸發(fā)器定義。

所以我們可以通過將觸發(fā)器文件復(fù)制到備份文件夾來備份mysql觸發(fā)器,還可以使用mysqldump工具備份觸發(fā)器。

使用限制

mysql觸發(fā)器覆蓋標(biāo)準(zhǔn)SQL中定義的所有功能,但是,在應(yīng)用程序中使用它們也會有一些限制:

  • 使用在SHOW,LOAD DATA,LOAD TABLE,BACKUP DATABASE,RESTORE,F(xiàn)LUSH和RETURN語句之上。
  • 使用隱式或明確提交或回滾的語句,如COMMIT,ROLLBACK,START TRANSACTION,LOCK/UNLOCK TABLES,ALTER,CREATE,DROP,RENAME等。
  • 使用準(zhǔn)備語句,如PREPARE,EXECUTE等
  • 使用動態(tài)SQL語句。

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

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

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

您可能感興趣的文章:
  • mysql 觸發(fā)器語法與應(yīng)用示例
  • MySql視圖觸發(fā)器存儲過程詳解
  • mysql觸發(fā)器原理與用法實例分析
  • mysql日志觸發(fā)器實現(xiàn)代碼
  • mysql觸發(fā)器之觸發(fā)器的增刪改查操作示例
  • mysql觸發(fā)器之創(chuàng)建多個觸發(fā)器操作實例分析
  • mysql觸發(fā)器之創(chuàng)建使用觸發(fā)器簡單示例
  • MySQL 觸發(fā)器定義與用法簡單實例
  • MySQL觸發(fā)器概念、原理與用法詳解
  • Mysql中禁用與啟動觸發(fā)器教程【推薦】
  • 詳解MySQL數(shù)據(jù)庫之觸發(fā)器

標(biāo)簽:陽江 黃石 果洛 來賓 煙臺 鞍山 赤峰 河北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql觸發(fā)器簡介、創(chuàng)建觸發(fā)器及使用限制分析》,本文關(guān)鍵詞  mysql,觸發(fā)器,簡介,創(chuàng)建,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql觸發(fā)器簡介、創(chuàng)建觸發(fā)器及使用限制分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于mysql觸發(fā)器簡介、創(chuàng)建觸發(fā)器及使用限制分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    运城市| 建平县| 文安县| 四川省| 商洛市| 呼图壁县| 南开区| 望谟县| 新乡市| 长沙市| 临城县| 双流县| 南丰县| 塔城市| 盐城市| 班玛县| 武川县| 高密市| 西平县| 邹平县| 名山县| 石渠县| 香格里拉县| 灌南县| 张家港市| 安吉县| 阜平县| 正蓝旗| 图木舒克市| 中宁县| 嘉祥县| 个旧市| 许昌县| 芜湖县| 平罗县| 临沭县| 武山县| 七台河市| 丘北县| 曲麻莱县| 庐江县|