10

我目前正在探索将变更数据捕获作为存储时态数据库的选项。这很棒,因为它只存储增量并且似乎可以解决我的问题。当我启用 CDC 时,一堆表格出现在System Tables.

查询时cdc.dbo_MyTable,我可以看到表上发生的所有更改。现在,我将如何构建历史观?例如,如果我想查看我的桌子在特定日期的状态,我该怎么做呢?这甚至可能吗?

看起来我需要获取日志并开始将它应用到我的原始表上,但我想知道是否有内置的方法可以做到这一点。有什么建议么?

我正在研究的一些用例:

  • 了解图在特定时间点的状态
  • 给定两个不同时间的图,知道不同的链接集(这可能可以在构建表后使用 EXCEPT 子句获得)
4

3 回答 3

6

这是可能的,但不是我害怕的内置方式。您将不得不手动重建时间线。

鉴于更改跟踪表提供 tran_end_time,即属性值应被视为持久的时间,您必须进行查询以获取表状态的所有不同时期,加入跟踪的属性更改然后旋转(以与表格相同的形式进行演示)。不要忘记与表状态本身联合以获取尚未更改/跟踪的值以确保完整性。

简化后的最终结果应如下所示

RN PK PropA   PropB   FromDate          ToDate
1  1  'Ver1'  'Ver1'  2012-01-01 09:00  2012-01-02 08:00
2  1  'Ver1'  'Ver2'  2012-01-02 08:00  2012-01-03 07:00
3  1  'Ver2'  'Ver2'  2012-01-03 07:00  *getdate()*
4  2  'Ver1'  'Ver1'  2012-01-01 05:00  2012-01-02 06:00
5  2  'Ver1'  'Ver2'  2012-01-02 06:00  2012-01-03 01:00
6  2  'Ver2'  'Ver2'  2012-01-03 01:00  *getdate()*

请注意,如果未删除该行,则getdate()有效,在这种情况下,应将其替换为删除日期

编辑,用于 2 个用例。第一点很容易解决,它是构建时间对象图然后过滤的问题:

declare @pointInTime datetime = '20120102 10:00';
select * from Reconstructed_TG where FromDate <= @pointInTime and @pointInTime < ToDate

正如您所指出的,第二点可以使用 EXCEPT 子句轻松生成。鉴于上述查询:

declare @pointInTimeA datetime = '20120102 10:00';
declare @pointInTimeB datetime = '20120103 01:00';
select * from Reconstructed_TG where FromDate <= @pointInTimeA and @pointInTimeA < ToDate
EXCEPT
select * from Reconstructed_TG where FromDate <= @pointInTimeB and @pointInTimeB < ToDate

但是该except子句仅显示具有至少一个不同列值的行;我不知道这些信息对人眼是否真的有意义。根据您的需要,直接处理cdc数据的查询可能更合适。

于 2012-08-14T12:44:54.313 回答
0

我不确定这一点,从来没有做过类似的事情,但也许你可以在表中添加一个列“changeset”,它可以跟踪你在表上所做的更改,每次有事务时获取 max(changeset (如果我应该写这是作为答案或评论...我是新来的)

无论如何,希望它有帮助...

于 2012-08-17T01:01:42.417 回答
0

您可能想查看自 2005 年以来已内置到 SQL Server 中的 Snapshots。

如果您只需要几个时间点,这些对您最有用,但它们可以帮助您跟踪复杂数据库中的所有表。

这些是增量,所以Compared to a full copy of a database, however, snapshots are highly space efficient. A snapshot requires only enough storage for the pages that change during its lifetime. Generally, snapshots are kept for a limited time, so their size is not a major concern.

于 2012-08-14T16:53:51.967 回答