无法获取在sql中的历史表中更新的列名

whitzsjs  于 2021-07-26  发布在  Java
关注(0)|答案(1)|浏览(197)

我在SQLServer中有一个表,其中有很多列可以每次更新。现在,我需要一个触发器,它可以插入到一个历史表中,我已经创建了一个在主表中更新的值。历史表就像this:varname(要存储主表中更新的列的名称,请输入id(主表中行的id)、oldvalue(更新的旧值)、newvalue(新值)、date(更新的日期)。我正在使用这段代码,但我希望触发器自动检测更改的列,并将它们的名称存储在varname列中。请记住,在主表的一行中可以更新多个字段,因此如果更新3个字段,历史表将添加3行,其中包含正在发生的更新以及主表中各自的列名和新旧值。在[dbo].[maintable]上创建触发器[dbo].updateonmaintable,更新后作为开始

INSERT [dbo].[Historical] (VarName, ID, OldValue, NewValue, Date)
        SELECT ===> the code here
        FROM inserted i
        INNER JOIN deleted d
            ON i.ID = d.ID

结束去我想要一个代码,填补我的历史表,因为我解释。

eyh26e7m

eyh26e7m1#

首先,您的结构要求数据类型与历史表中的列兼容。
第二,您需要取消IVOT,然后从那里开始工作:

with ic as (
      select i.id, v.*
      from inserted i cross apply
           (values ('col1', i.col1), ('col2', i.col2), ('col3', i.col3)
           ) v(col, val)
     ),
     dc as (
      select d.id, v.*
      from deleted d cross apply
           (values ('col1', d.col1), ('col2', idcol2), ('col3', d.col3)
           ) v(col, val)
     )
insert into historical (varname, id, oldvalue, newvalue, date)
    select ic.col, ic.id, dc.val, ic.val, getdate
    from ic join
         dc
         on ic.id = dc.id and
            ic.col = dc.col and
            (ic.val <> dc.val or
             ic.val is null and dc.val is not null or
             ic.val is not null and dc.val is null
            );

请注意,如果列具有不同的类型,则需要在 values() 声明。

相关问题