触发器语句中使用了两种特殊的表:deleted    表和    inserted    表。Microsoft®    SQL  Server  2000 自动创建和管理这些表。可以使用这两个临时的驻留内存的表测试某些数据修改的效果及设置触发器操作的条件;然而,不能直接对表中的数据进行更改。   
   
   inserted    和    deleted    表主要用于触发器中:     
   
   扩展表间引用完整性。   
   
   在以视图为基础的基表中插入或更新数据。   
   
   检查错误并基于错误采取行动。   
     
   找到数据修改前后表状态的差异,并基于此差异采取行动。     
   Deleted    表用于存储    DELETE    和    UPDATE    语句所影响的行的复本。在执行    DELETE    或    UPDATE    语句时,行从触发器表中删除,并传输到    deleted    表中。Deleted    表和触发器表通常没有相同的行。   
   
   Inserted    表用于存储    INSERT    和    UPDATE    语句所影响的行的副本。在一个插入或更新事务处理中,新建行被同时添加到    inserted    表和触发器表中。Inserted    表中的行是触发器表中新行的副本。   
   
   更新事务类似于在删除之后执行插入;首先旧行被复制到    deleted    表中,然后新行被复制到触发器表和    inserted    表中。   
   
   在设置触发器条件时,应当为引发触发器的操作恰当使用    inserted    和    deleted    表。虽然在测试    INSERT    时引用    deleted    表或在测试    DELETE    时引用    inserted    表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。   
   
   说明      如果触发器操作取决于一个数据修改所影响的行数,应该为多行数据修改(基于    SELECT    语句的    INSERT、DELETE    或    UPDATE)使用测试(如检查    @@ROWCOUNT),然后采取相应的对策。   
   
   
   SQL    Server™    2000    不允许    AFTER    触发器引用    inserted    和    deleted    表中的    text、ntext    或    image    列;然而,允许    INSTEAD    OF    触发器引用这些列。有关更多信息,请参见    CREATE    TRIGGER。   
   
   在    INSTEAD    OF    触发器中使用    inserted    和    deleted    表   
   传递到在表上定义的    INSTEAD    OF    触发器的    inserted    和    deleted    表遵从与传递到    AFTER    触发器的    inserted    和    deleted    表相同的规则。inserted    和    deleted    表的格式与在其上定义    INSTEAD    OF    触发器的表的格式相同。inserted    和    deleted    表中的每一列都直接映射到基表中的列。     
   
   有关引用带    INSTEAD    OF    触发器的表的    INSERT    或    UPDATE    语句何时必须提供列值的规则与表没有    INSTEAD    OF    触发器时相同:     
   不能为计算列或具有    timestamp    数据类型的列指定值。     
   不能为具有    IDENTITY    属性的列指定值,除非该列的    IDENTITY_INSERT    为    ON。当    IDENTITY_INSERT    为    ON    时,INSERT    语句必须提供一个值。     
   INSERT    语句必须为所有无    DEFAULT    约束的    NOT    NULL    列提供值。   
   
   对于除计算列、标识列或    timestamp    列以外的任何列,任何允许空值的列或具有    DEFAULT    定义的    NOT    NULL    列的值都是可选的。     
   当    INSERT、UPDATE    或    DELETE    语句引用具有    INSTEAD    OF    触发器的视图时,数据库引擎将调用该触发器,而不是对任何表采取任何直接操作。即使为视图生成的    inserted    和    deleted    表中的信息格式与基表中的数据格式不同,该触发器在生成执行基表中的请求操作所需的任何语句时,仍必须使用    inserted    和    deleted    表中的信息。   
   
   传递到在视图上定义的    INSTEAD    OF    触发器的    inserted    和    deleted    表格式与为该视图定义的    SELECT    语句的选择列表相匹配。例如:   
   
   CREATE    VIEW    EmployeeNames    (EmployeeID,    LName,    FName)   
   AS   
   SELECT    EmployeeID,    LastName,    FirstName   
   FROM    Northwind.dbo.Employees   
   
   视图的结果集有三列:一个    int    列和两个    nvarchar    列。传递到在视图上定义的    INSTEAD    OF    触发器的    inserted    和    deleted    表也具有名为    EmployeeID    的    int    列、名为    LName    的    nvarchar    列和名为    FName    的    nvarchar    列。   
   
   视图的选择列表还包含不直接映射到单个基表列的表达式。一些视图表达式(如常量调用或函数调用)可能不引用任何列,这类表达式会被忽略。复杂的表达式会引用多列,但在    inserted    和    deleted    表中,每个插入的行仅有一个值。如果视图中的简单表达式引用具有复杂表达式的计算列,则这些简单表达式也有同样的问题。视图上的    INSTEAD    OF    触发器必须处理这些类型的表达式。有关更多信息,请参见视图上    INSTEAD    OF    触发器中的表达式和计算列。
顺便说一下,当对某张表建立触发器后,分3种情况讨论
1.插入操作(Insert)
Inserted表有数据,Deleted表无数据
2.删除操作(Delete)
Inserted表无数据,Deleted表有数据
3.更新操作(Update)
Inserted表有数据(新数据),Deleted表有数据(旧数据)

转载于:https://www.cnblogs.com/s021368/articles/1280439.html

deleted 表和 inserted 表相关推荐

  1. (DML触发器)如何正确理解触发器的deleted表和inserted表(转)

    在触发器的设计当中,有很多的同学总是不了解怎样善用触发器来解决问题,其实问题在于他们不理解触发器最重要的两个表:inserted表和deleted表,假如你理解这两表的话,许多关于的触发器的问题就迎刃 ...

  2. 触发器deleted 表和 inserted 表详解(转)

    create trigger updateDeleteTime on user for update as begin   update user set UpdateTime=(getdate()) ...

  3. MySQL中有inserted表吗_使用 inserted 和 deleted 表

    创建和维护数据库 使用 inserted 和 deleted 表 触发器语句中使用了两种特殊的表:deleted 表和 inserted 表.Microsoft® SQL Server™ 2000 自 ...

  4. MySQL中有inserted表吗_SQL触发器中的inserted表和deleted表

    简介:开发也有年头了,但是触发器确实用的比较少,但是无容置疑触发器确实不错, 最近项目要求需要用到的触发器特别多.频繁,觉得很有必要记录和积累下. 在触发器语句中用两个特殊的表一个是deleted表和 ...

  5. mysql inserted表_触发器中的inserted表和deleted表

    触发器语句中使用了两种特殊的表:deleted 表和 inserted 表.Microsoft? SQL Server 2000 自动创建和管理这些表.可以使用这两个临时的驻留内存的表测试某些数据修改 ...

  6. mysql inserted表_数据库触发器inserted和deleted详解

    create trigger updateDeleteTime on user for update as begin update user set UpdateTime=(getdate()) f ...

  7. mysql inserted表_数据库inserted的搜索结果-阿里云开发者社区

    SQL 2000中的触发器使用 触发器是数据库应用中的重用工具,它的应用很广泛,这几天写一个化学数据统计方面的软件,需要根据采样,自动计算方差,在这里,我使用了触发器. 下面我摘录了SQL Serve ...

  8. 在创建触发器时出现不能在 'inserted' 表和 'deleted' 表中使用 text、ntext 或 image 列...

    1. 不能在 'inserted' 表和 'deleted' 表中使用 text.ntext 或 image 列 在 create trigger trg on t1 for update 改成 cr ...

  9. SQL server触发器 inserted表和deleted表用法

    inserted表和deleted表用于存放对表中数据行的修改信息,他们是触发器执行时自动创建的,放在内存中,是临时表.当触发器工作完成,它们也被删除.它们是只读表,不能向它们写入内容. insert ...

最新文章

  1. 周立功-成功心法(2):通过讲故事营销自己
  2. 白话Elasticsearch22- 深度探秘搜索技术之match_phrase_prefix实现search-time搜索推荐
  3. LeetCode 01两数之和02两数相加
  4. 【远程操控】Pycharm远程连接服务器之本地显示独立的plot窗口
  5. Build a Machine Learning Portfolio(构建机器学习投资组合)
  6. android 字体描边实现,android文字描边功能的实现
  7. 使用jd-gui+javassist修改已编译好的class文件
  8. python做的游戏可以导出吗_Python视频教程
  9. 电脑异常关闭导致dubbo启动错误问题
  10. 设计模式(十一):享元模式
  11. keepalived 邮件通知
  12. 最大似然估计_什么是最大似然估计
  13. 数据挖掘之模糊集与模糊逻辑
  14. html中动态添加元素属性值,JavaScript实现动态添加、移除元素或属性的方法分析...
  15. 计算机组成原理cu_计算机组成原理19----控制单元CU设计
  16. 为了保护您的视力,请对电脑作如下设置
  17. 为什么远程计算机后会黑屏,电脑上钉钉怎么远程,为什么远程后黑屏?
  18. 拿R来画画(六):很漂亮的Cleveland点图
  19. 春夏秋冬又一春之Redis持久化
  20. XSS朝花夕拾代码简单分析(XSSgame)

热门文章

  1. 快准狠!Intel论文揭示自家车牌识别算法:LPRNet
  2. 搞定python不就那么点事吗?
  3. 解密:90后程序员青睐哪些互联网公司?
  4. ARM全新Armv9架构:10年最大更新、增强AI和security能力
  5. 动手学pytorch之通俗易懂何为卷积-深度AI科普团队
  6. python及numpy,pandas易混淆的点
  7. 计算机视觉 | Python OpenCV 3 使用背景减除进行目标检测
  8. 自动驾驶使用贝塞尔曲线进行静态障碍物避障测试
  9. python3.5安装scrapy_win7+Python3.5下scrapy的安装方法
  10. 网络安全与渗透测试工具集合