【问题标题】:How to find out the rows affected in SQL Profiler or trace?如何找出 SQL Profiler 或跟踪中受影响的行?
【发布时间】:2016-12-23 13:20:44
【问题描述】:

我正在使用跟踪来记录通过系统运行的所有删除或更新查询。问题是,如果我运行像 DELETE FROM [dbo].[Artist] WHERE ArtistId>280 这样的查询,我知道有多少行被删除,但我无法找出哪些行被删除(他们拥有的数据)。

我正在考虑将此作为一个日志记录系统,因此如果可能的话,查看哪些行受到影响以及它们拥有哪些数据会很有用。我真的不想在这项工作中使用触发器,但如果必须(并且如果可行的话)我会这样做。

【问题讨论】:

  • SQL Profiler 只会显示对数据库执行的操作,我认为它不能显示删除记录后的值 - 我想你'必须为此使用触发器。

标签: sql-server tsql sql-server-2014 trace sql-server-profiler


【解决方案1】:

如果您需要原始数据并计划将所有已删除的数据存储在单独的表中,为什么不直接从逻辑上删除原始数据而不是物理上删除呢?即

UPDATE dbo.Artist SET Artist_deleted = 1 WHERE ArtistId>280

那么您只需要在当前表中添加一列,而不是创建新表和脚本来支持这些。如果您担心磁盘空间/性能等问题,您可以根据已删除标志对当前表进行分区。

【讨论】:

  • 可能也值得同时设置一个DateDeleted 值。实际上,您可能希望在删除时存储许多不同的值作为审计。
  • 是的,这似乎是要走的路。正如@3N1GM4 所说,我还需要添加一个 DateDeleted ,但这是它背后的基本逻辑。 (数据库不是我的,但他们正在讨论实现相同的东西,所以这一切都很好。)
猜你喜欢
  • 2021-04-29
  • 1970-01-01
  • 1970-01-01
  • 2015-08-06
  • 2012-10-01
  • 1970-01-01
  • 1970-01-01
  • 2010-10-26
  • 2017-09-21
相关资源
最近更新 更多