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

          軟件下載吧

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

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

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

          前言

          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

          相關下載

          查看所有評論+

          網友評論

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

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 日本韩国黄色一区二区三区| 国精产品一区一区三区| 亚洲色精品VR一区区三区| 中文字幕无线码一区| 日韩精品无码一区二区三区四区 | 国产拳头交一区二区| 日韩一区二区三区免费体验| 怡红院一区二区三区| 中文字幕国产一区| 一区高清大胆人体| 国产女人乱人伦精品一区二区| 亚洲毛片不卡av在线播放一区| 日韩视频一区二区三区| 国产精品电影一区| 国产av一区二区三区日韩| 97av麻豆蜜桃一区二区| 99精品高清视频一区二区| 久久久av波多野一区二区| 麻豆视频一区二区三区| 免费无码一区二区三区| 国产福利电影一区二区三区久久久久成人精品综合 | 久久se精品一区二区国产 | 自拍日韩亚洲一区在线| 无码8090精品久久一区| 亚洲熟女www一区二区三区| 国产精品男男视频一区二区三区| 任你躁国语自产一区在| 国产日韩一区二区三免费高清 | 中文字幕一区二区三区在线不卡 | 亚洲sm另类一区二区三区| 精品一区二区三区中文字幕 | 国产精品亚洲专区一区| 国模私拍福利一区二区| 人妻无码一区二区三区免费| 国产成人综合精品一区| 色欲精品国产一区二区三区AV| 亚洲无圣光一区二区| 日韩一区二区三区四区不卡| 亚洲综合一区二区精品导航| 国产av熟女一区二区三区| 亲子乱av一区二区三区|