版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 上半年教師資格考試《中學(xué)綜合素質(zhì)》真題及答案
- 2024-2030年中國婚慶策劃市場競爭力分析發(fā)展策略研究報告
- 2024-2030年中國地板抹布融資商業(yè)計劃書
- 2024-2030年中國四連體無塵服商業(yè)計劃書
- 2024年版施工勞務(wù)非材料供應(yīng)承包合同版
- 2024年版零售商墊資協(xié)議樣式版B版
- 2024年三舊改造建設(shè)項目合作協(xié)議書范本-智慧城市配套3篇
- 2024年小學(xué)二年級數(shù)學(xué)(北京版)-萬以內(nèi)數(shù)的加減法(二)-1教案
- 洛陽職業(yè)技術(shù)學(xué)院《視頻編輯》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025年德州貨運從業(yè)資格模擬考試題
- 概率期末考試試題答案《概率論與數(shù)理統(tǒng)計B》
- 大學(xué)校園交通規(guī)劃以南京林業(yè)大學(xué)為例
- 山東2023泰安銀行春季校園招聘25人上岸提分題庫3套【500題帶答案含詳解】
- GB/T 11446.9-2013電子級水中微粒的儀器測試方法
- GB 8537-2018食品安全國家標(biāo)準(zhǔn)飲用天然礦泉水
- GB 31247-2014電纜及光纜燃燒性能分級
- 斯倫貝謝智能完井工具介紹
- 百詞斬-定語從句課件-(;)
- 珍惜時間主題班會-做時間的主人課件
- 市政工程施工總體部署
- 護士準(zhǔn)入申請表
評論
0/150
提交評論