【SQL觸發器、事務、鎖的概念和應用】

【SQL觸發器、事務、鎖的概念和應用】

1.觸發器

(一)觸發器概述
1.觸發器的定義

觸發器(Trigger)是一種特殊的存儲過程,它與表緊密相連,可以是表定義的一部分。當預定義的事件(如用戶修改指定表或者視圖中的數據)發生時,觸發器會自動執行。
觸發器基于一個表創建,但是可以對多個表進行操作。因此觸發器可以用來對表實施復雜的完整性約束,當觸發器保存的數據改變時,觸發器被自動激活,從而防止對數據的不正確修改。觸發器的優點如下。
(1)觸發器自動執行,在對表的數據做了任何修改(如手工輸入或者使用程序采集的操作)之后立即激活。
(2)觸發器可以通過數據庫中的相關表進行層疊更改。這比直接把代碼寫在前臺的做法更安全合理。
(3)觸發器可以強制限制,這些限制比用CHECK約束定義的更復雜。與CHECK約束不同的是,觸發器可以引用其他表中的列。
2.觸發器的分類
在SQL Server系統中,按照觸發事件的不同,可以把提供的觸發器分成兩大類型,即DDL觸發器和DML觸發器。
(1)DML觸發器
DML 觸發器為特殊類型的存儲過程,可在發生數據操作語言(DML)事件時自動生效,以便影響觸發器中定義的表或視圖。DML事件包括 INSERT、UPDATE或DELETE語句。DML觸發器可用于強制業務規則和數據完整性、查詢其他表并包括復雜的 Transact-SQL語句。將觸發器和觸發它的語句作為可在觸發器內回滾的單個事務對待。如果檢測到錯誤(如磁盤空間不足),則整個事務自動回滾。
(2)DDL觸發器
DDL觸發器將激發響應各種數據定義語言(DDL)事件。這些事件主要與以關鍵字CREATE、ALTER、DROP、GRANT、DENY、REVOKE或UPDATE STATISTICS開頭的Transact-SQL語句對應。
(二)創建觸發器
1.DML觸發器
因為DML觸發器是一種特殊的存儲過程,所以DML觸發器的創建和存儲過程的創建方式有很多相似之處,創建DML觸發器的基本語法如下。

CREATE TRIGGER trigger_name
ON {table|view}
{{{FOR|AFTER|INSTEAD OF}{[UPDATE [[,][INSERT][,][DELETE] ]ASsql_statement}
}

CREATETRIGGER語句中,主要參數的含義如下。

trigger_name:是要創建的觸發器的名稱。
table|view:是在其上執行觸發器的表或者視圖,有時稱為觸發器表或者觸發器視圖。可以選擇是否指定表或者視圖的所有者。
FOR、AFTER、INSTEAD OF:指定觸發器觸發的時機。
AFTER:指定觸發器只有在SQL語句中指定的所有操作都已成功執行后才觸發,只有在所有的引用級聯操作和約束檢查成功完成后,才能執行此觸發器。如果僅指定FOR關鍵字,則AFTER是默認設置。
INSTEAD OF:指定執行觸發器而不是執行觸發的SQL語句,從而替代觸發語句的操作。在表或視圖上,每個INSERT、UPDATE或DELETE語句最多可以定義一個INSTEAD OF觸發器。
DELETE、INSERT、UPDATE:指定在表或視圖上執行哪些語句時將觸發觸發器的關鍵字。必須至少指定一個選項。在觸發器定義中允許使用以任意順序組合的這些關鍵字。如果指定的選項多于一個,需用逗號分隔這些選項。
sql_statement:指定觸發器執行的Transact-SQL語句。

【例1】 創建一個觸發器,當class表中的班級編號變更時,同時更新student表中的相應班級編號信息。

USE grademanager
GO
CREATETRIGGERtrig_班級信息更新
ON class
FOR UPDATE
AS
IF UPDATE(classno) 
BEGIN
UPDATE student SET classno=(SELECT classno FROM inserted) 
WHERE classnoIN(SELECT classno FROM deleted) 
END

【例2】 創建一個觸發器,用于在grademanager數據庫中刪除student表的一個學生信息時,級聯刪除該學生對應sc表中的成績信息。
默認時,由于student表和sc表在sno列上存在外鍵約束,因此不允許直接刪除student表中

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/79665.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/79665.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/79665.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

設計模式每日硬核訓練 Day 17:中介者模式(Mediator Pattern)完整講解與實戰應用

🔄 回顧 Day 16:責任鏈模式小結 在 Day 16 中,我們學習了責任鏈模式(Chain of Responsibility Pattern): 將請求沿鏈傳遞,節點可選擇處理或傳遞下一節點。實現了請求發送者與多個處理者的解耦…

如何提升個人情商?

引言 提升個人情商(EQ)是一個持續的自我修煉過程,涉及自我認知、情緒管理、人際溝通等多個方面。以下是一些具體且可實踐的方法,幫助你逐步提升情商: 一、提升自我覺察能力 1. 記錄情緒日記 每天回顧自己的情緒…

STM32Cube-FreeRTOS任務調度與任務管理-筆記

STM32Cube-FreeRTOS任務調度與任務管理-筆記 一、任務調度機制1.1 調度算法類型 二、搶占式調度實現與分析2.1 時間片輪轉機制2.2 調度觸發條件2.3 搶占式調度例子 三、合作式調度實現3.1 核心邏輯3.1 合作式調度例子 四、任務管理函數詳解4.1 任務創建4.1.1 動態創建任務4.1.2…

對稱加密算法(AES、ChaCha20和SM4)Python實現——密碼學基礎(Python出現No module named “Crypto” 解決方案)

文章目錄 一、對稱加密算法基礎1.1 對稱加密算法的基本原理1.2 對稱加密的主要工作模式 二、AES加密算法詳解2.1 AES基本介紹2.2 AES加密過程2.3 Python中實現AES加密Python出現No module named “Crypto” 解決方案 2.4 AES的安全考量 三、ChaCha20加密算法3.1 ChaCha20基本介…

MATLAB圖像加密案例

下面是一個使用 MATLAB 編寫的簡單圖像塊置亂加密/解密程序,主要利用了函數來組織代碼。 這個程序通過將圖像分割成小塊,然后根據一個密鑰(用于隨機數生成器種子)打亂這些塊的順序來實現加密。解密過程則使用相同的密鑰恢復原始塊順序。 核心思想: 分塊: 將圖像劃分為 …

阿里云服務器全棧技術指導手冊(2025版)

阿里云服務器全棧技術指導手冊(2025版) 一、基礎配置與核心架構設計 1. 精準實例選型策略 ? 通用計算場景:選擇ECS通用型(如ecs.g7)實例,搭載第三代Intel Xeon處理器,適合Web應用、中小型數…

word批量轉pdf工具

word批量轉pdf工具 圖片 說到了辦公,怎能不提PDF轉換哦? 這是一款一鍵就可以批量word轉換為PDF的小工具,簡直是VB界的一股清流。 圖片 操作簡單到不行,只要把需要轉換的word文件和這個工具放在同一個文件夾里,雙擊…

C++類_協變返回類型

協變返回類型定義 在 C11 中,協變返回類型是指在基類和派生類的虛函數重寫時,派生類中重寫的虛函數的返回類型可以是基類中對應虛函數返回類型的派生類型。也就是說,當基類的虛函數返回一個基類指針或引用時,派生類中重寫該虛函數…

補充:建立實體類與數據表的映射關系

目錄 前言 1 成員變量數據類型和字段類型 保持對應 2 成員變量的變量名,應采用小駝峰命名法 3 數據表中的主鍵如id 應采用自增方式 4 數據表中的時間類型數據與實體類中的時間類型的變量無法實現自動映射可以使用JsonFormat 注解 4.1 配置全局時間處理器&#x…

HTML/CSS 魔法第二彈:會逃跑的調皮按鈕(懸停自動閃避)

引言 在網頁設計中,交互性是吸引用戶的關鍵因素之一。普通的按鈕在用戶懸停時可能只是顏色或樣式發生改變,但今天我們要創造一個 “調皮” 的按鈕,當用戶鼠標懸停在上面時,它會自動閃避,仿佛在和用戶玩游戲。本文將詳…

**Java面試:技術大比拼**

互聯網大廠Java面試:一場嚴肅與搞笑交織的技術拷問 場景:互聯網大廠面試間 面試官(嚴肅):請坐。馬小帥,我們今天主要考察一下你在Java技術棧上的掌握程度,以及如何將這些技術應用于實際業務場景…

25考頻高的前端面試題

請求失敗會彈出一個toast,如何保證批量請求失敗,只彈出一個toast 設置全局標志位,定義一個全局變量(如isToastShown)來表示是否已經彈出過toast。在請求失敗的處理邏輯中,首先檢查該標志位。如果尚未彈出toast&#xf…

命令模式(Command Pattern)詳解

文章目錄 1. 什么是命令模式?2. 為什么需要命令模式?3. 命令模式的核心概念4. 命令模式的結構5. 命令模式的基本實現5.1 簡單的燈光控制示例5.2 家電控制示例6. 帶有撤銷功能的命令模式6.1 修改命令接口6.2 實現可撤銷的燈光命令6.3 實現可撤銷的風扇命令6.4 修改調用者,支持…

《Vue3學習手記8》

vue3中的一些API shallowRef ( ) 和shallowReactive ( ) shallowRef (淺層響應式) 1.作用:創建一個響應式數據,但只對頂層屬性進行響應式處理。 2.用法: const originalref(...) const original2shallowRef(original) 3.特點:只跟蹤引用值的變化,不關心…

雙列集合——map集合和三種遍歷方式

雙列集合的特點 鍵和值一一對應,每個鍵只能對應自己的值 一個鍵和值整體稱為鍵值對或鍵值對對象,java中叫做entry對象。 map常見的api map接口中定義了雙列集合所有的共性方法,下面三個實現類就沒有什么額外新的方法要學習了。 map接口…

Linux安裝部署Postgresql數據庫

聯網安裝方案 Linux能在線安裝依賴組件的前提下,可以快速安裝部署PG數據庫,安裝過程使用root管理員帳號: 首先,使用如下命令自動下載Postgresql組件: # 在openEuler、Fedora或CentOS 8上,你可能會使用&a…

供應鏈算法整理(二)--- 智能補貨

供應鏈業務的目標價值是:優化貨品的供給、銷售提供支撐,以降低成本,提高時效、收益,最終提升用戶體驗。基于目標價值,整體的算法模塊分為:智能選品、智能預測、品倉鋪貨、智能補貨、智能調撥、倉網路由、快…

vscode 個性化

vscode 個性化 設置 吸頂效果 使用前使用后 設置方法 VS Code 的粘性滾動預覽 - 類似于 Excel 的凍結首行 插件 代碼片段分享 - CodeSnap 使用方式 CtrlShiftP輸入CodeSnap 喚起插件選擇代碼 行內報錯提示 - Error Lens 使用前使用后 VSCode Error Lens插件介紹&…

Rockermq的部署與使用(0-1)

?RocketMQ? 是阿里巴巴開源的一款 ?分布式消息中間件,具有高吞吐、低延遲、高可用等特點,廣泛應用于多個領域,包括異步通信解耦、企業解決方案、金融支付、電信、電子商務、快遞物流、廣告營銷、社交、即時通信、移動應用、手游、視頻、物…

軟件測試報告機構如何保障軟件質量并維護其安全性?

軟件測試報告機構在軟件開發流程里起著十分關鍵的作用,它可以保障軟件的質量,它還能夠維護軟件的安全性。下面,我們就來深入了解一下這類機構。 機構作用 軟件測試報告機構是軟件質量的“把關者”,能對軟件進行全面評估&#xf…