下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 數據庫 > MS_SQL > SQL開發知識:關于SQL Server數據庫觸發器詳解

SQL開發知識:關于SQL Server數據庫觸發器詳解

時間:2024-02-05 12:47作者:下載吧人氣:34

前言

SQL Server觸發器在非常有爭議的主題。它們能以較低的成本提供便利,但經常被開發人員、DBA誤用,導致性能瓶頸或維護性挑戰。

本文簡要回顧了觸發器,并深入討論了如何有效地使用觸發器,以及何時觸發器會使開發人員陷入難以逃脫的困境。

雖然本文中的所有演示都是在SQL Server中進行的,但這里提供的建議是大多數數據庫通用的。觸發器帶來的挑戰在MySQL、PostgreSQL、MongoDB和許多其他應用中也可以看到。

什么是觸發器

可以在數據庫或表上定義SQL Server觸發器,它允許代碼在發生特定操作時自動執行。本文主要關注表上的DML觸發器,因為它們往往被過度使用。相反,數據庫的DDL觸發器通常更集中,對性能的危害更小。

觸發器是對表中數據更改時進行計算的一組代碼。觸發器可以定義為在插入、更新、刪除或這些操作的任何組合上執行。MERGE操作可以觸發語句中每個操作的觸發器。

觸發器可以定義為INSTEAD OF或AFTER。AFTER觸發器發生在數據寫入表之后,是一組獨立的操作,和寫入表的操作在同一事務執行,但在寫入發生之后執行。如果觸發器失敗,原始操作也會失敗。INSTEAD OF觸發器替換調用的寫操作。插入、更新或刪除操作永遠不會發生,而是執行觸發器的內容。

觸發器允許在發生寫操作時執行TSQL,而不管這些寫操作的來源是什么。它們通常用于在希望確保執行寫操作時運行關鍵操作,如日志記錄、驗證或其他DML。這很方便,寫操作可以來自API、應用程序代碼、發布腳本,或者內部流程,觸發器無論如何都會觸發。

觸發器是什么樣的

用WideWorldImporters示例數據庫中的Sales.Orders 表舉例,假設需要記錄該表上的所有更新或刪除操作,以及有關更改發生的一些細節。這個操作可以通過修改代碼來完成,但是這樣做需要對表的代碼寫入中的每個位置進行更改。通過觸發器解決這一問題,可以采取以下步驟:

1. 創建一個日志表來接受寫入的數據。下面的TSQL創建了一個簡單日志表,以及一些添加的數據點:

CREATE TABLE Sales.Orders_log
( Orders_log_ID int NOT NULL IDENTITY(1,1)
CONSTRAINT PK_Sales_Orders_log PRIMARY KEY CLUSTERED,
OrderID int NOT NULL,
CustomerID_Old int NOT NULL,
CustomerID_New int NOT NULL,
SalespersonPersonID_Old int NOT NULL,
SalespersonPersonID_New int NOT NULL,
PickedByPersonID_Old int NULL,
PickedByPersonID_New int NULL,
ContactPersonID_Old int NOT NULL,
ContactPersonID_New int NOT NULL,
BackorderOrderID_Old int NULL,
BackorderOrderID_New int NULL,
OrderDate_Old date NOT NULL,
OrderDate_New date NOT NULL,
ExpectedDeliveryDate_Old date NOT NULL,
ExpectedDeliveryDate_New date NOT NULL,
CustomerPurchaseOrderNumber_Old nvarchar(20) NULL,
CustomerPurchaseOrderNumber_New nvarchar(20) NULL,
IsUndersupplyBackordered_Old bit NOT NULL,
IsUndersupplyBackordered_New bit NOT NULL,
Comments_Old nvarchar(max) NULL,
Comments_New nvarchar(max) NULL,
DeliveryInstructions_Old nvarchar(max) NULL,
DeliveryInstructions_New nvarchar(max) NULL,
InternalComments_Old nvarchar(max) NULL,
InternalComments_New nvarchar(max) NULL,
PickingCompletedWhen_Old datetime2(7) NULL,
PickingCompletedWhen_New datetime2(7) NULL,
LastEditedBy_Old int NOT NULL,
LastEditedBy_New int NOT NULL,
LastEditedWhen_Old datetime2(7) NOT NULL,
LastEditedWhen_New datetime2(7) NOT NULL,
ActionType VARCHAR(6) NOT NULL,
ActionTime DATETIME2(3) NOT NULL,
UserName VARCHAR(128) NULL);

標簽MSSQL,SQLServer,技術文檔,數據庫,SQLSERVER

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 黄色性生活毛片| 欧美黑人疯狂性受xxxxx喷水| 国产一级爱做c片免费昨晚你| 国产精品久久久久久麻豆一区| 国产精品综合网| 91天堂素人精品系列网站| 天堂网在线www| juy031白木优子中文字幕| 性欧美大战久久久久久久久| 中文字幕视频一区| 日本三级午夜理伦三级三| 久久国产精彩视频| 日韩欧美精品在线视频| 亚洲AV成人噜噜无码网站| 欧美亚洲国产片在线播放| 亚洲国产精品一区二区三区久久| 欧美视频日韩视频| 亚洲狠狠狠一区二区三区| 波多野结衣电影免费在线观看| 伊人久久大香线蕉av一区二区| 男男动漫全程肉无删减彩漫| 免费看成年人网站| 精东传媒国产app| 免费少妇荡乳情欲视频| 看全免费的一级毛片| 免费毛片a线观看| 皇上啊轻点灬大ji巴太粗太h| 免费观看无遮挡www的小视频| 精品亚洲麻豆1区2区3区| 冬月枫亚洲高清在线观看| 精品中文字幕乱码一区二区| 免费网站无遮挡| 目中无人在线观看免费高清完整电影| 免费a在线观看| 爱情岛论坛亚洲品质自拍视频| 亚洲色四在线视频观看| 没有被爱过的女人在线| 亚洲欧美成人永久第一网站| 欧美成人黄色片| 亚洲中文久久精品无码1| 晚上看b站直播软件|