当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:21:00  来源:本站整理

SQL Server数据库技术(73)[MSSQL防范]

赞助商链接



  本文“SQL Server数据库技术(73)[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

   从以上的介绍中我们可以看出触发器具有强盛的功效,那么MS sql server 是若何管理触发器来完成这些任务呢?下面我们将对其工作原理及实现做较为具体的介绍.

    每个触发器有两个特别的表:插入表和删除表.这两个表是逻辑表,并且这两个表是由系统管理的,存储在内存中,不是存储在数据库中,因此不答应用户直接对其改正.这两个表的构造老是与被该触发器作用的表有相同的表构造.这两个表是动态驻留在内存中的,当触发器工作完成,这两个表也被删除.这两个表主要保存因用户操作而被影响到的原数据值或新数据值.别的,这两个表是只读的,即用户不能向这两个表写入内容,但可以引用表中的数据.比方可用以下语句查看DELETED 表中的信息:
select * from deleted
下面具体介绍这两个表的功效:

12.7.1 插入表的功效
    对一个定义了插入范例触发器的表来说,一旦对该表履行了插入操作,那么对向该表插入的全部行来说,都有一个呼应的副本存放到插入表中.即插入表就是用来存储向原表插入的内容.

12.7.2 删除表的功效

    对一个定义了删除范例触发器的表来说,一旦对该表履行了删除操作,则将全部的删除行存放至删除表中.这样做的目的是,一旦触发器碰到了逼迫它中止的语句被履行时,删除的那些行可以从删除表中得以恢复.

    需求夸大的是,更新操作包含两个部份,即先将更新的内容去掉,然后将新值插入.因此对一个定义了更新范例触发器的表来说,当报告会更新操作时,在删除表中存放了旧值,然后在插入表中存放新值.

    由于触发器仅当被定义的操作被履行时才被激活,即仅当在履行插入、删除、和更新操作时,触发器将履行.每条SQL 语句仅能激活触发器一次,大概存在一条语句影响多条记录的情形.在这种情形下就需求变量@@rowcount 的值,该变量存储了一条SQL 语句履行后所影响的记录数,可以利用该值对触发器的SQL 语句履行后所影响的记录求合计值.普通来说,首先要用IF 语句测试@@rowcount 的值以肯定背面的语句能否履行.

  以上是“SQL Server数据库技术(73)[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • Windows 搭配 IIS7 PHP MySQL 环境
  • sqlserver索引的原理及索引成立的注意事项小结
  • SQL Join的一些总结(实例)
  • SQL的Join利用图解教程
  • SQL中JOIN和UNION辨别、用法及示例介绍
  • 关于SQL中CTE(公用表表达式)(Common Table Expression)的总结
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .