A1的trigger应该分成三个,insert, update, delete 各一个

解决方案 »

  1.   

    CREATE TRIGGER [SyncOE] ON [dbo].[A1] 
    FOR INSERT,DELETE
    AS
    SET IDENTITY_INSERT B..B1 ON
    DELETE B..B1 WHERE  E_ID IN (SELECT E_ID from DELETED)INSERT B..B1(E_ID,BRANCH,E_TAX_NO,E_NAME,E_ADDRESS,E_HY,E_CONTAC,E_CONTAC_ID,
    E_PAYTAXNO,REMARK,EDITDATE) SELECT * FROM INSERTED
    SET IDENTITY_INSERT B..B1 OFFCREATE TRIGGER [SyncOE2] ON [dbo].[A1] 
    FOR UPDATE
    AS
    SET IDENTITY_INSERT B..B1 ONupdate B..b1
    set E_ID=a.E_ID ,BRANCH=a.BRANCH...
    from inserted a
    where B..b1.E_ID=a.E.id
      

  2.   

    CREATE TRIGGER [SyncOE] ON [dbo].[A1] 
    FOR INSERT,DELETE
    AS
    SET IDENTITY_INSERT B..B1 ON
    DELETE B..B1 WHERE  E_ID IN (SELECT E_ID from DELETED)INSERT B..B1(E_ID,BRANCH,E_TAX_NO,E_NAME,E_ADDRESS,E_HY,E_CONTAC,E_CONTAC_ID,
    E_PAYTAXNO,REMARK,EDITDATE) SELECT * FROM INSERTED
    SET IDENTITY_INSERT B..B1 OFFCREATE TRIGGER [SyncOE2] ON [dbo].[A1] 
    FOR UPDATE
    AS
    SET IDENTITY_INSERT B..B1 ONupdate B..b1
    set E_ID=a.E_ID ,BRANCH=a.BRANCH...
    from inserted a
    where B..b1.E_ID=a.E.id
      

  3.   

    你原来的update触发器错了,变成了update的时候也往b1插入数据,所以会导致
    b1的触发器触发再往b2写数据
      

  4.   

    你在查询分析器里试试往update A b表是什么结果
      

  5.   

    请看如下SQL SERVER中的帮助说明:
    使用 inserted 和 deleted 表
    触发器语句中使用了两种特殊的表: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 表不会引起任何错误,但是在这种情形下这些触发器测试表中不会包含任何行。
     
       现在明白了错误的原因了吧!!!