SQL Server Trigger switching Insert,Delete,Update

后端 未结 5 1920
慢半拍i
慢半拍i 2021-02-09 01:39

Hello is possible to switch between DML commands/operations (Insert,Delete,Update) on Trigger Body?, I try to snippet some T-SQL for understand me better :

CREA         


        
相关标签:
5条回答
  • 2021-02-09 02:15

    You can use one trigger for all commands/operations by use union join;

    CREATE TRIGGER DML_ON_TABLEA
     ON  TABLEA
    AFTER INSERT,DELETE,UPDATE
    AS 
    BEGIN
        SET NOCOUNT ON;
       --logic for insert
        insert into Backup_table (columns_name) select columns_name from inserted i
        --logic for delete
       UNION ALL
        insert into Backup_table (columns_name) select columns_name from deleted d
    END
    GO
    

    --note update command like inserted command but have another command deleted

    0 讨论(0)
  • 2021-02-09 02:18

    I think the general way to do this is to create a trigger for each action, like so:

    CREATE TRIGGER INSERT_ON_TABLEA   
    ON  TABLEA   
    AFTER INSERT 
    AS 
    BEGIN    
    SET NOCOUNT ON;    
    -- INSERT ON AUX TABLEB
    END
    GO
    
    CREATE TRIGGER DELETE_ON_TABLEA   
    ON  TABLEA   
    AFTER DELETE
    AS 
    BEGIN    
    SET NOCOUNT ON;    
    -- DELETE ON AUX TABLEB
    END
    GO
    
    0 讨论(0)
  • 2021-02-09 02:20

    You can use the inserted and deleted tables to see what changes were made to the table.

    For an UPDATE, the deleted table contains the old version of the row, and inserted the new version.

    DELETE and INSERT use their own table as you would expect.

    0 讨论(0)
  • 2021-02-09 02:24

    You can have three separate triggers, one for INSERT one for UPDATE one for DELETE. Since each trigger is different, there is no need for switch logic.

    0 讨论(0)
  • 2021-02-09 02:39

    I will show you a simple way to check this in SQL Server 2000 or 2005 (you forgot to mention which version you are using), but in general I agree with Remus that you should break these up into separate triggers:

    DECLARE @i INT, @d INT;
    SELECT @i = COUNT(*) FROM inserted;
    SELECT @d = COUNT(*) FROM deleted;
    IF @i + @d > 0
    BEGIN
        IF @i > 0 AND @d = 0
        BEGIN
            -- logic for insert
        END
    
        IF @i > 0 AND @d > 0
        BEGIN
            -- logic for update
        END
    
        IF @i = 0 AND @d > 0
        BEGIN
            -- logic for delete
        END
    END
    

    Note that this may not be perfectly forward-compatible due to the complexity MERGE introduces in SQL Server 2008. See this Connect item for more information:

    • MERGE can cause a trigger to fire multiple times

    So if you are planning to use SQL Server 2008 and MERGE in the future, then this is even more reason to split the trigger up into a trigger for each type of DML operation.

    (And if you want more reasons to avoid MERGE, read this.)

    0 讨论(0)
提交回复
热议问题