SQL Server誤區30日談 第4天 DDL觸發器就是INSTEAD OF觸發器

來源:互聯網
上載者:User

誤區 #4: DDL觸發器(SQL Server 2005之後被引入)就是INSTEAD OF觸發器

這是錯誤的

DDL觸發器的實現原理其實就是一個AFTER觸發器。這個意思是先發生DDL操作,然後觸發器再捕捉操作(當然如果你在觸發器內寫了Rollback,則也可能復原)。

存在Rollback也意味著這個觸發器並不像你想象的那麼輕量,來看下面的例子:

ALTER TABLE MyBigTable ADD MyNewNonNullColumn VARCHAR (20) DEFAULT 'Paul'

如果存在一個defined for ALTER_TABLE事件的DDL觸發器,或是一個更寬泛的事件比如DDL_TABLE_EVENTS。上面那個DDL代碼將會對錶中每一行資料加進新列,之後觸發觸發器操作。如果你的觸發器中存在復原來阻止DDL操作發生,那麼這個代價可不小(不信的話你自己看看這麼做後產生的日誌)。

當然更好的辦法是對ALTER設定GRANT或是DENY許可權,或是僅僅允許通過你建立的預存程序進行DDL操作。

但不管怎麼樣,雖然DDL觸發器可以達到禁止DDL的操作的目的,但代價昂貴。而DDL觸發器的好處是允許記錄某些人做了某些修改表之類的操作,所以我並不是說不允許DDL觸發器,而是要小心使用。

Kimberly有一篇非常好的關於DDL觸發器的博文:"EXECUTE AS" and an important update your DDL Triggers (for auditing or prevention)”。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.