触发器语句中使用了两种特殊的表: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. C++忽略第三方库的警告
  2. 创业计划书模板(周鸿祎口述)
  3. 1.svn无法连接,2.svn日志无法显示,3.日志无法修改
  4. wxWidgets:wxToolBar 示例
  5. 利用Zabbix ODBC monitoring监控MySQL
  6. (上)python3 selenium3 从框架实现代码学习selenium让你事半功倍
  7. JavaSE第九天20160815
  8. 从当前元素继续寻找_169. 多数元素
  9. 【codeforces 718 CD】C. Sasha and ArrayD. Andrew and Chemistry
  10. 深度了解视频直播CDN技术
  11. SAP 数据表相关信息
  12. opencv-contrib-Python编译module ‘cv2.cv2‘ has no attribute ‘xfeatures2d‘
  13. 【QA】哈工大张伟男:任务型对话系统
  14. Unity2 学习 制作和动态加载预制体
  15. 360企业版退出密码
  16. 爬FH... ... 爽!
  17. 性别分为男子组和女子组
  18. 蓝牙HC05模块探究-设置AT指令
  19. 深圳大澳湾度假团建攻略
  20. 【树莓派不吃灰】基础篇④ Raspberry Pi上搭建NodeJS运行环境

热门文章

  1. 亚马逊招聘,无人超市研发部门
  2. 多媒体领域顶会,ACM MM 2020 会议论文下载
  3. 17毫秒每帧!实时语义分割与深度估计
  4. Kaggle新上比赛:Google AI发起地域包容性图像识别竞赛
  5. PyTorch | 通过torch.eye创建单位对角矩阵 | torch.eye()如何使用?torch.eye()例子 | torch.eye()使用方法
  6. 小米集团2021未来星专项招聘计划!
  7. 清华又揽一位AI大牛!前微软全球副总裁开招博士生!
  8. 计算机操作员(中级工)理论知识试卷,计算机操作员中级工理论试卷.doc
  9. Android把数组从大到小排列,Android SparseArray 排序
  10. oracle复杂的子查询,Oracle 子查询(复杂select语句)