避免SQL Server 觸發器死迴圈

來源:互聯網
上載者:User

        在使用SQL Server時,有時候希望針對資料表中某一欄位的修改執行一段觸發器代碼,比如修改了人員名稱時,我們希望資料庫會自動執行一代碼來修改同一資料表中的姓名拼音首字母欄位。如果使用After Update觸發器則會讓SQL Server崩潰掉,那麼有什麼辦法可以避免這種死迴圈嗎?答案是肯定的,我可以在觸發器中判斷使用者是否修改了姓名欄位,如果是則執行後續更新代碼,如果使用者修改了其他欄位,則不執行任何代碼。 

        假設有一張表格儲存體客戶的資訊,第一個欄位是Visitor_ID,第二個欄位Visitor_Name,第三個欄位是Visitor_PY_Code。我們針對新增和更新動作寫兩個觸發器。

        針對新增的觸發器很容易寫,現在的問題是在更新的觸發器,如果再使用Update語句就會迴圈執行觸發器了,系統會崩潰掉的。我們希望只針對單一欄位的更新執行觸發器。還好SQL提供了COLUMNS_UPDATED()函數,能夠判斷出哪一欄位被更新。於是將更新的觸發器寫成如下:

CREATE TRIGGER [UpdatePYCodeOnly] ON [dbo].[Visitor] 
FOR UPDATE
AS
IF (COLUMNS_UPDATED() & 2) = 2 BEGIN
declare
  @VisitorID int,
  @NameStr nvarchar(50)
  Select @VisitorID = Visitor_ID, @NameStr = Visitor_Name From Inserted
  Update Visitor Set NamePINYIN = dbo.GetPYCode(@NameStr) Where Visitor_ID = @VisitorID
END

        在使用COLUMNS_UPDATED()函數需要注意以下幾點

  1. 表中第一個欄位序號為0,第二個欄位序號為1,依此類推
  2. 表中的欄位順序不要改動

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.