国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

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

2024-08-31 00:56:47
字體:
來源:轉載
供稿:網友

誤區 #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)”。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 大兴区| 朝阳市| 株洲市| 恩平市| 商河县| 米易县| 伊吾县| 北海市| 凉城县| 柳林县| 蓬安县| 大同市| 麻江县| 濉溪县| 江津市| 女性| 南开区| 正定县| 博客| 汝城县| 丰顺县| 清新县| 松江区| 仁布县| 瑞丽市| 涡阳县| 汽车| 霍林郭勒市| 开远市| 垣曲县| 蒙城县| 六安市| 安乡县| 舞钢市| 株洲市| 兴安盟| 望奎县| 柯坪县| 赣州市| 红河县| 黄大仙区|