《MySQL數(shù)據(jù)庫應(yīng)用與管理(第3版)》 課件 魯大林 第9章 觸發(fā)器_第1頁
《MySQL數(shù)據(jù)庫應(yīng)用與管理(第3版)》 課件 魯大林 第9章 觸發(fā)器_第2頁
《MySQL數(shù)據(jù)庫應(yīng)用與管理(第3版)》 課件 魯大林 第9章 觸發(fā)器_第3頁
《MySQL數(shù)據(jù)庫應(yīng)用與管理(第3版)》 課件 魯大林 第9章 觸發(fā)器_第4頁
《MySQL數(shù)據(jù)庫應(yīng)用與管理(第3版)》 課件 魯大林 第9章 觸發(fā)器_第5頁
已閱讀5頁,還剩21頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

觸發(fā)器

觸發(fā)器概述

觸發(fā)器概述觸發(fā)器是一種特殊的存儲過程,且不同于一般的存儲過程。觸發(fā)器主要是通過事件進行觸發(fā)而被執(zhí)行,而一般的存儲過程則是通過存儲過程名稱被直接調(diào)用。觸發(fā)器是一個功能強大的工具,與表緊密連接,可以看作是表結(jié)構(gòu)定義的一部分。觸發(fā)器基于一個表創(chuàng)建,但可以操作多個表。它可以在向數(shù)據(jù)表中插入、修改或刪除數(shù)據(jù)時進行檢查,以保證數(shù)據(jù)完整性和一致性。當(dāng)用戶修改(INSERT、UPDATE或DELETE)指定表中的數(shù)據(jù)時,該表中的相應(yīng)的觸發(fā)器就會自動執(zhí)行。謝謝觸發(fā)器

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

本節(jié)內(nèi)容1.使用CREATETRIGGER語句創(chuàng)建觸發(fā)器2.觸發(fā)器中的NEW和OLD關(guān)鍵字3.創(chuàng)建插入觸發(fā)器4.創(chuàng)建更新觸發(fā)器5.創(chuàng)建刪除觸發(fā)器創(chuàng)建觸發(fā)器創(chuàng)建觸發(fā)器使用CREATETRIGGER語句,其語法格式如下:

CREATETRIGGER<觸發(fā)器名> BEFORE|AFTER INSERT|UPDATE|DELETE ON<表>FOREACHROW <觸發(fā)器過程體>1.使用CREATETRIGGER語句創(chuàng)建觸發(fā)器創(chuàng)建觸發(fā)器說明:BEFORE|AFTER:觸發(fā)器觸發(fā)的時機。INSERT|UPDATE|DELETE:觸發(fā)器觸發(fā)的事件。FOREACHROW:對于觸發(fā)事件影響的每一行,都要激活觸發(fā)器動作。觸發(fā)器過程體:事件發(fā)生,觸發(fā)器需要執(zhí)行的任務(wù)。同一張表、同一觸發(fā)事件、同一觸發(fā)時機只能創(chuàng)建一個觸發(fā)器。觸發(fā)器執(zhí)行的順序BEFORE觸發(fā)器、表操作(INSERT、UPDATE、DELETE)和AFTER觸發(fā)器。1.使用CREATETRIGGER語句創(chuàng)建觸發(fā)器創(chuàng)建觸發(fā)器MySQL的觸發(fā)器無任何輸入和輸出參數(shù),其內(nèi)部使用的參數(shù)就是新舊兩條記錄NEW和OLD的字段,用來完成數(shù)據(jù)表之間的觸發(fā)操作,來保證數(shù)據(jù)庫的一致性、完整性。NEW表示的新插入的數(shù)據(jù),OLD表示的是原來的數(shù)據(jù):當(dāng)使用INSERT語句的時候,插入的那一條數(shù)據(jù)相對于插入數(shù)據(jù)后的表來說就是NEW。當(dāng)使用DELETE語句的時候,刪除的那一條數(shù)據(jù)相對于刪除數(shù)據(jù)后的表來說就是OLD。當(dāng)使用UPDATE語句的時候,修改前的那一條數(shù)據(jù)相對于修改數(shù)據(jù)后的表來說就是OLD;修改后的那一條數(shù)據(jù)相對于修改數(shù)據(jù)后的表來說就是NEW。2.觸發(fā)器中的NEW和OLD關(guān)鍵字創(chuàng)建觸發(fā)器在觸發(fā)器BEFORE中可以在對NEW進行賦值和取值;而在AFTER中只能對NEW進行取值,不能賦值。訪問觸發(fā)器中NEW和OLD的語法格式如下: NEW.column_name OLD.column_name2.觸發(fā)器中的NEW和OLD關(guān)鍵字創(chuàng)建觸發(fā)器創(chuàng)建插入觸發(fā)器使用INSERT關(guān)鍵字,即當(dāng)指定的數(shù)據(jù)表發(fā)生數(shù)據(jù)插入操作時,自動觸發(fā)并執(zhí)行指定的任務(wù);可設(shè)置在插入前觸發(fā)、還是在插入后觸發(fā),分別使用BEFORE或者AFTER關(guān)鍵字。3.創(chuàng)建插入觸發(fā)器操作案例知識點概述示例9-1運行結(jié)果如下:創(chuàng)建一個由INSERT觸發(fā)的前觸發(fā)器tr_insertStudent,一旦在學(xué)生表(student)中插入一行數(shù)據(jù)之前,檢查性別是否為“男”或者“女”,如果不是,則設(shè)置為“男”。操作案例知識點概述示例9-2運行結(jié)果如下:向?qū)W生表(student)中插入一條學(xué)生記錄,驗證示例9-1中的觸發(fā)器tr_insertStudent。創(chuàng)建觸發(fā)器創(chuàng)建更新觸發(fā)器使用UPDATE關(guān)鍵字,即當(dāng)指定的數(shù)據(jù)表發(fā)生數(shù)據(jù)更新操作時,自動觸發(fā)并執(zhí)行指定的任務(wù);可設(shè)置在更新前觸發(fā)、還是在更新后觸發(fā),分別使用BEFORE或者AFTER關(guān)鍵字。4.創(chuàng)建更新觸發(fā)器操作案例知識點概述示例9-3運行結(jié)果如下:創(chuàng)建一個由UPDATE觸發(fā)的后觸發(fā)器tr_updateStuScore,一旦在成績表(score)中修改了某一學(xué)生的某一課程的成績之后,把修改時間、學(xué)號、課程編號、修改前成績、修改后成績保存到數(shù)據(jù)表trigger_log中。操作案例知識點概述示例9-4運行結(jié)果如下:修改成績表(score)中的一條學(xué)生的課程成績,驗證示例9-3中的觸發(fā)器tr_updateStuScore。創(chuàng)建觸發(fā)器創(chuàng)建刪除觸發(fā)器使用DELETE關(guān)鍵字,即當(dāng)指定的數(shù)據(jù)表發(fā)生數(shù)據(jù)刪除操作時,自動觸發(fā)并執(zhí)行指定的任務(wù);可設(shè)置在刪除前觸發(fā)、還是在刪除后觸發(fā),分別使用BEFORE或者AFTER關(guān)鍵字。5.創(chuàng)建刪除觸發(fā)器操作案例知識點概述示例9-5運行結(jié)果如下:創(chuàng)建一個由DELETE觸發(fā)的前觸發(fā)器tr_deleteStudent,一旦在學(xué)生表(student)中刪除一行數(shù)據(jù)之前,刪除該學(xué)生的所有成績記錄。操作案例知識點概述示例9-6運行結(jié)果如下:刪除學(xué)生表(student)中的一條學(xué)生記錄,驗證示例9-5中的觸發(fā)器tr_deleteStudent。謝謝觸發(fā)器

修改觸發(fā)器

修改觸發(fā)器MySQL中沒有類似ALTERTRIGGER語句,因此,我們不能象修改其他數(shù)據(jù)庫對象,例如表、視圖和存儲過程那樣修改觸發(fā)器。如果要修改觸發(fā)器,可以先刪除原觸發(fā)器,再以相同的名稱、并使用新的代碼重新創(chuàng)建。謝謝觸發(fā)器

刪除觸

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論