• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL Server误区30日谈 第4天 DDL触发器就是INSTEAD OF触发器

    误区 #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)”。

    您可能感兴趣的文章:
    • 关于喜忧参半的SQL Server触发器详解
    • 利用SQL Server触发器实现表的历史修改痕迹记录
    • SQLSERVER对加密的存储过程、视图、触发器进行解密(推荐)
    • SQL Server 使用触发器(trigger)发送电子邮件步骤详解
    • SQL Server实现用触发器捕获DML操作的会话信息【实例】
    • SQL Server:触发器实例详解
    • SqlServer触发器详解
    • SqlServer实现类似Oracle的before触发器示例
    • SQL SERVER中各类触发器的完整语法及参数说明
    • SQL SERVER 触发器介绍
    • SQL Server 触发器详情
    上一篇:SQL Server误区30日谈 第3天 即时文件初始化特性可以在SQL Server中开启和关闭
    下一篇:浅谈SQL Server 对于内存的管理[图文]
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL Server误区30日谈 第4天 DDL触发器就是INSTEAD OF触发器 SQL,Server,误区,30日谈,第,