CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  疑难问题

前触发器和后触发器对于使用都来讲或者性能上来讲有什么不同,在线等

楼主2004kingbear()2006-07-01 21:20:09 在 MS-SQL Server / 疑难问题 提问

用了触发器,后触发器的内容会不会执行。  
  例如:我在新增一张表单的数据时,放在前触器中做保存前检查,检查成功保存,不成功取消。和后触发器中做同样的检查动作有什么区别。 问题点数:18、回复次数:3Top

1 楼LouisXIV(夜游神)回复于 2006-07-01 21:27:24 得分 5

这样的操作没有什么区别Top

2 楼LouisXIV(夜游神)回复于 2006-07-01 21:59:00 得分 5

你可以看看这个  
  http://dev.csdn.net/develop/article/83/83639.shtm  
   
  个人觉得两者在实际应用上没有太大的区别Top

3 楼liaowei0627()回复于 2006-07-01 23:25:46 得分 8

lz说的前触发器是指instead   of触发器吧,instead   of这个短语是代替的意思,就是说这个触发器会取代触发自己的事物执行,比如:  
  create一个由insert语句触发的instead   of触发器,当你执行对应的insert语句时,会显示插入1行成功的信息,但是实际上目标表中并没有这一行数据。  
  如果lz再create一个after触发器,并定义由同一个表的insert语句触发,那么在执行相应的insert语句时,会发现这个after触发器根本不会被触发,当然前提是这两个触发器内部都不要包含对这个表的insert语句。  
  按照lz的例子:就必须在instead   of触发器中除了检查业务逻辑外,再包括insert语句,否则就不会有insert语句执行,虽然这个触发器是被insert语句触发的。  
  附:事物执行的流程  
  1.执行identity   insert检查(如果存在自动增长列);  
  2.检查为空性约束(null或者not   null);  
  3.检查数据类型;  
  4.执行instead   of触发器(如果存在instead   of触发器,将取消执行触发它的DML语句也就是下面的8、9、11都不会执行);  
  5.检查主键约束;  
  6.检查check约束;  
  7.检查外键约束;  
  8.执行DML语句,并更新事物日志;  
  9.执行after触发器;  
  10.提交事物;  
  11.写入数据文件。Top

相关问题

关键词

得分解答快速导航

  • 帖主:2004kingbear
  • LouisXIV
  • LouisXIV
  • liaowei0627

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo