SQL Server誤區30日談 第4天 DDL觸發器就是INSTEAD建站
導讀:1建站知識DDL觸發器的實現原理其實就是一個AFTER觸發器。這個意思是先發生DDL操作,然后觸發器再捕捉操作(當然如果你在觸發seo網站優化培訓網站建設公司。
誤區 #4: DDL觸發器(SQL Server 2005之后被引入)就是INSTEAD OF觸發器
這seo網站優化軟件是錯誤的
DDL觸發器的實現原理其實就是一個AFTER觸發器。這個意思是先發生DDL操作,然后觸發器再捕捉操作(當然如果你在觸發器內寫了Rollback,則也可能回滾)。
存在Rollback也意味著這個觸發器并不像你想象的那么輕量,來看下面的例子:
ALTER TABLE MyBigTable Aseo網站優化培訓DD 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 impo網站推廣優化seortant update your DDL Triggers (for auditing or prevention)”。
相關seo網站優化培訓網站建設公司。聲明: 本文由我的SEOUC技術文章主頁發布于:2023-05-24 ,文章SQL Server誤區30日談 第4天 DDL觸發器就是INSTEAD建站主要講述觸發器,誤區,SQL網站建設源碼以及服務器配置搭建相關技術文章。轉載請保留鏈接: http://www.bifwcx.com/article/web_6555.html