日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

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

軟件下載吧

當(dāng)前位置:軟件下載吧 > 數(shù)據(jù)庫(kù) > MS_SQL > SQL開(kāi)發(fā)知識(shí):關(guān)于SQL Server數(shù)據(jù)庫(kù)觸發(fā)器詳解

SQL開(kāi)發(fā)知識(shí):關(guān)于SQL Server數(shù)據(jù)庫(kù)觸發(fā)器詳解

時(shí)間:2024-02-05 12:47作者:下載吧人氣:36

前言

SQL Server觸發(fā)器在非常有爭(zhēng)議的主題。它們能以較低的成本提供便利,但經(jīng)常被開(kāi)發(fā)人員、DBA誤用,導(dǎo)致性能瓶頸或維護(hù)性挑戰(zhàn)。

本文簡(jiǎn)要回顧了觸發(fā)器,并深入討論了如何有效地使用觸發(fā)器,以及何時(shí)觸發(fā)器會(huì)使開(kāi)發(fā)人員陷入難以逃脫的困境。

雖然本文中的所有演示都是在SQL Server中進(jìn)行的,但這里提供的建議是大多數(shù)數(shù)據(jù)庫(kù)通用的。觸發(fā)器帶來(lái)的挑戰(zhàn)在MySQL、PostgreSQL、MongoDB和許多其他應(yīng)用中也可以看到。

什么是觸發(fā)器

可以在數(shù)據(jù)庫(kù)或表上定義SQL Server觸發(fā)器,它允許代碼在發(fā)生特定操作時(shí)自動(dòng)執(zhí)行。本文主要關(guān)注表上的DML觸發(fā)器,因?yàn)樗鼈兺贿^(guò)度使用。相反,數(shù)據(jù)庫(kù)的DDL觸發(fā)器通常更集中,對(duì)性能的危害更小。

觸發(fā)器是對(duì)表中數(shù)據(jù)更改時(shí)進(jìn)行計(jì)算的一組代碼。觸發(fā)器可以定義為在插入、更新、刪除或這些操作的任何組合上執(zhí)行。MERGE操作可以觸發(fā)語(yǔ)句中每個(gè)操作的觸發(fā)器。

觸發(fā)器可以定義為INSTEAD OF或AFTER。AFTER觸發(fā)器發(fā)生在數(shù)據(jù)寫入表之后,是一組獨(dú)立的操作,和寫入表的操作在同一事務(wù)執(zhí)行,但在寫入發(fā)生之后執(zhí)行。如果觸發(fā)器失敗,原始操作也會(huì)失敗。INSTEAD OF觸發(fā)器替換調(diào)用的寫操作。插入、更新或刪除操作永遠(yuǎn)不會(huì)發(fā)生,而是執(zhí)行觸發(fā)器的內(nèi)容。

觸發(fā)器允許在發(fā)生寫操作時(shí)執(zhí)行TSQL,而不管這些寫操作的來(lái)源是什么。它們通常用于在希望確保執(zhí)行寫操作時(shí)運(yùn)行關(guān)鍵操作,如日志記錄、驗(yàn)證或其他DML。這很方便,寫操作可以來(lái)自API、應(yīng)用程序代碼、發(fā)布腳本,或者內(nèi)部流程,觸發(fā)器無(wú)論如何都會(huì)觸發(fā)。

觸發(fā)器是什么樣的

用WideWorldImporters示例數(shù)據(jù)庫(kù)中的Sales.Orders 表舉例,假設(shè)需要記錄該表上的所有更新或刪除操作,以及有關(guān)更改發(fā)生的一些細(xì)節(jié)。這個(gè)操作可以通過(guò)修改代碼來(lái)完成,但是這樣做需要對(duì)表的代碼寫入中的每個(gè)位置進(jìn)行更改。通過(guò)觸發(fā)器解決這一問(wèn)題,可以采取以下步驟:

1. 創(chuàng)建一個(gè)日志表來(lái)接受寫入的數(shù)據(jù)。下面的TSQL創(chuàng)建了一個(gè)簡(jiǎn)單日志表,以及一些添加的數(shù)據(jù)點(diǎn):

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);

標(biāo)簽MSSQL,SQLServer,技術(shù)文檔,數(shù)據(jù)庫(kù),SQLSERVER

相關(guān)下載

查看所有評(píng)論+

網(wǎng)友評(píng)論

網(wǎng)友
您的評(píng)論需要經(jīng)過(guò)審核才能顯示

熱門閱覽

最新排行

公眾號(hào)

主站蜘蛛池模板: 成人视视 | 国产精品中文字幕在线观看 | 私人玩物福利 | 日韩一级片视频 | 国产欧美专区在线观看 | 真正全免费视频a毛片 | 99久久伊人一区二区yy5099 | 手机看福利片 | 久久精品国产亚洲高清 | 一级毛片a免费播放王色 | 日韩欧美在线播放视频 | 亚洲精品区一区二区三区四 | 国产97在线观看 | 三级国产在线 | 国产第一福利影院 | 大尺度福利视频奶水在线 | 久久人视频 | 国产精品久久久久影视不卡 | 中国日本高清免费视频网 | 一区二区三区四区视频在线观看 | 女人被男人躁得好爽免费文 | 色综合日韩 | 国产欧美另类久久精品91 | 九九视频在线观看视频 | 国内精品久久久久久久星辰影视 | 131美女爱做免费毛片 | 在线精品视频免费观看 | 福利视频在线午夜老司机 | 精品久久久在线观看 | 成年人免费视频观看 | 午夜宅男在线永久免费观看网 | 亚洲欧美日本视频 | 国产91精选在线观看网站 | 亚洲第一页在线视频 | 免费人成年短视频在线观看免费网站 | 免费国产黄网站在线观看视频 | 太平公主三级dvd | 国产精品免费综合一区视频 | 成人国产亚洲欧美成人综合网 | 91丨九色丨首页在线观看 | 一级片在线免费看 |