SQLSERVER触发器内INSERT,UPDATE,DELETE三种状态

转载 2015年07月08日 14:40:36

一个触发器内三种INSERT,UPDATE,DELETE状态

CREATE   TRIGGER   tr_T_A   ON     T_A   for   INSERT,UPDATE,DELETE         
  如IF   exists   (select   *   from   inserted)   and   not   exists   (select   *   from   deleted)   则为   INSERT   
  如IF   exists(select   *   from   inserted   )   and   exists   (select   *   from   deleted)   则为   UPDATE   
  如IF   exists   (select   *   from   deleted)   and   not   exists   (select   *   from   inserted)则为   DELETE  

插入操作(Insert):Inserted表有数据,Deleted表无数据 
删除操作(Delete):Inserted表无数据,Deleted表有数据 
更新操作(Update):Inserted表有数据(新数据),Deleted表有数据(旧数据) 
 
笔者用到的案例:
create TRIGGER [risk].[Entry_Head_port_Exchange_Trigger]
   ON  [RiskH800].[risk].[ENTRY_HEAD]
   AFTER INSERT,UPDATE
AS 
DECLARE @COUNT INT
    DECLARE @MANUAL_NO_COUNT INT
    IF EXISTS (SELECT 1 FROM INSERTED)
       IF EXISTS(SELECT 1 FROM DELETED)
       BEGIN
       SELECT @COUNT = COUNT(*) FROM risk.ENTRY_HEAD_port_EXCHANGE WHERE ENTRY_ID = (select ENTRY_ID FROM DELETED)
       SELECT @MANUAL_NO_COUNT = COUNT(MANUAL_NO) FROM DELETED where substring(MANUAL_NO,1,1)= 'B' or substring(MANUAL_NO,1,1)='C'
           IF @COUNT <=0 AND @MANUAL_NO_COUNT>0
           INSERT INTO risk.ENTRY_HEAD_port_EXCHANGE(ENTRY_ID,CREATE_DATE)(SELECT ENTRY_ID,getdate() FROM DELETED)
       END
       ELSE
       BEGIN
       SELECT @COUNT = COUNT(*) FROM risk.ENTRY_HEAD_port_EXCHANGE WHERE ENTRY_ID = (select ENTRY_ID FROM INSERTED)
           SELECT @MANUAL_NO_COUNT = COUNT(MANUAL_NO) FROM INSERTED where substring(MANUAL_NO,1,1)= 'B' or substring(MANUAL_NO,1,1)='C'
           IF @COUNT <=0 AND @MANUAL_NO_COUNT>0
           INSERT INTO risk.ENTRY_HEAD_port_EXCHANGE(ENTRY_ID,CREATE_DATE)(SELECT ENTRY_ID,getdate() FROM INSERTED)
       END

相关文章推荐

创建INSERT、DELETE、UPDATE 触发器示例

触发器是基于一个表创建的,但是可以针对多个表进行操作。所以触发器可以用来对表实施复杂的完整性的约束,当触发器所保存的数据发生改变时,触发器所保存的数据发生改变时,触发器被自动激活,从而防止对数据的不正...

SQLSERVER触发器触发INSERT,UPDATE,DELETE三种状态

转自:http://yunlongzheng.blog.51cto.com/788996/780110 一个触发器内三种INSERT,UPDATE,DELETE状态 CREATE   TRIGG...

SQLSERVER触发器内INSERT,UPDATE,DELETE三种状态

一个触发器内三种INSERT,UPDATE,DELETE状态 CREATE   TRIGGER   tr_T_A   ON     T_A   for   INSERT,UPDATE,DELETE...
  • leowzl
  • leowzl
  • 2016年07月23日 23:02
  • 1526

Sql Server触发器,往一个表中插入数据

Sql Server触发器,往一个表中插入数据

3.SQL Server DML触发器--检测对指定列的UPDATE或INSERT操作

本文摘自《锋利的SQL》:http://item.jd.com/10380652.html 14.1.3 检测对指定列的UPDATE或INSERT操作 对于INSERT或UPDATE触发器,可以使用U...

SQL Server 触发器中 Update的方法 判断一列是否更新

Every one know `s that : 触发器中我可能会因为某一个字段的值被修改了,我才会触发这个Trigger,ok,我们会写   if  Update(Column1) 这样的语句,ok...

SQL Server 触发器:表的特定字段更新时,触发Update触发器

create trigger TR_MasterTable_Updateon MasterTableafter updateas if update ([Type])--当Type字段被更新时,才会触...
  • tjvictor
  • tjvictor
  • 2009年08月26日 10:22
  • 21683

SQLServer触发器的使用

基本语法 创建: create trigger trigger_name on {table_name view_name} {for After Instead of } [ insert,...

mysql在insert触发器里update当前数据

今天在学习触发器时遇到了一个问题: 为activities表创建一个insert触发器,初始化一些数据 CREATE DEFINER=`root`@`localhost` TRIGGER `initA...

ORACLE使用触发器更新数据

在CSDN中,帮别人 写了一个简单的触发器进行更新数据,中间牵扯到好几个问题 create or replace trigger tri_Aafter inserton test11DECLAREpr...
  • zftang
  • zftang
  • 2011年07月06日 01:19
  • 5685
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQLSERVER触发器内INSERT,UPDATE,DELETE三种状态
举报原因:
原因补充:

(最多只允许输入30个字)