SQL Server审计功能入门:更改跟踪(Change Tracking)

原文:SQL Server审计功能入门:更改跟踪(Change Tracking)

介绍

       更改跟踪是一种轻量型解决方案,它为应用程序提供了一种有效的更改跟踪机制。常规的,自定义变更跟踪和读取跟踪数据,会使用触发器,存储过程和记录变更的用户表等,

还需要保证访问一致和相关清理工作。 使用CT会减少额外工作量和保证访问一致性。

启用CT的表上必须得有主键,所有版本适用。为了保证更改信息的有效性,官方建议结合快照隔离使用。

CT只能提供:

                    哪些行/列发生了更改

                    被更改行的最新数据。

不能提供:更改发生的次数,中间值。

应用:离线缓存的更新,ETL更新

注意事项

                  1. 写入变更到变更记录表,所以执行计划会多一个操作符,增加开销。

                  2. 每个启用CT的表会创建一个内部更改表。

                  3. 对于用户表中每行的每个更改,都会向内部更改表中添加一行。  该行有一个较小的固定开销,外加一个大小等于主键列大小的可变开销。

                  4. 对于每个已提交的事务,都会向内部事务表中添加一行。

实现

1. 在库级别启用CT
       

alter database TestCT 

set change_tracking=on 

( 

  change_retention=2 days, 

  auto_cleanup=on 

)

2. 对要跟踪的对象启用CT

alter table sometable 

enable change_tracking 

go

3. 使用CHANGETABLE函数查看CT数据。SYS_CHANGE_VERSION是库中任何行的变改的最新版本号。

   返回行的最新更改数据:

SELECT t.* 

      , ct.* 

FROM dbo.SomeTable t 

CROSS APPLY CHANGETABLE(VERSION dbo.SomeTable, (ID), (t. ID)) AS ct;

   返回指定last_sync_versiion改变的数据:

DECLARE @version BIGINT = 2; 

SELECT t.* 

, ct.* 

FROM CHANGETABLE (CHANGES dbo.SomeTable, @version) AS ct 

      INNER JOIN dbo.SomeTable t ON t. ID = ct. ID 

Go

4. 对列启用CT

CREATE TABLE dbo.NewTable ( 

ID INT NOT NULL IDENTITY(1, 1) CONSTRAINT PK_NewTable PRIMARY KEY 

      , BigColumn VARCHAR(255) NOT NULL 

      , AnotherBigColumn VARCHAR(255) NOT NULL 

) 

GO 

ALTER TABLE NewTable 

ENABLE CHANGE_TRACKING 

WITH (TRACK_COLUMNS_UPDATED=ON)

5. 查询CT列的变更数据

    使用CHANGE_TRACKING_IS_COLUMN_IN_MASK结合CHANGETABLE

DECLARE @version BIGINT ; 

--get previous version 

SELECT @version= CHANGE_TRACKING_CURRENT_VERSION()-1; 

SELECT *, 

CHANGE_TRACKING_IS_COLUMN_IN_MASK( 

              COLUMNPROPERTY( OBJECT_ID('dbo.NewTable'),'BigColumn','COLUMNID'  

               ), 

         CT.SYS_CHANGE_COLUMNS 

              ) AS BigColumn_Changed, 

CHANGE_TRACKING_IS_COLUMN_IN_MASK( 

                                    COLUMNPROPERTY( 

                        OBJECT_ID('dbo.NewTable'), 

                        'AnotherBigColumn','COLUMNID' 

               ), 

         CT.SYS_CHANGE_COLUMNS 

              ) AS AnotherBigColumn_Changed 

FROM CHANGETABLE(CHANGES dbo.NewTable,@version) AS CT 

INNER JOIN dbo.NewTable NT 

ON CT.ID=NT.ID



总结



    1. 所谓轻量,是相对的。CT仍需要记录变更记录,需要额外的开销。

    2. CT只能记录最终值,所以实际应用中用得不多,只适用于特定场景。

时间: 2024-10-26 08:52:55

SQL Server审计功能入门:更改跟踪(Change Tracking)的相关文章

SQL Server审计功能入门:CDC(Change Data Capture)

原文:SQL Server审计功能入门:CDC(Change Data Capture) 介绍 SQL Server 2008引入了CDC(Change Data Capture),它能记录: 1. 哪些数据行发生了改变 2. 数据行变更的历史记录,而不仅仅是最终值. 跟CT(Change Tracking)相比,它通过作业实现异步变更跟踪(像事务复制),而CT是同步实现的.因此它对性能的影响较轻并且不会影响事务. 典型应用是在提取.传输和加载数据到其它数据源,就像图中的数据仓库. 实现 微软建

SQL Server审计功能入门:SQL Server审核 (SQL Server Audit)

原文:SQL Server审计功能入门:SQL Server审核 (SQL Server Audit) 介绍     Audit是SQL Server 2008之后才有的功能,它能告诉你"谁什么时候做了什么事情".具体是指审核SQL Server 数据库引擎实例或单独的数据库涉及到跟踪和记录数据库引擎中发生的事件.它的底层是基于扩展事件(Extented Event),所以其性能和灵活性相对较好.审核数据可以输出到审核文件.Windows安全日志和应用程序日志.     Audit都需

SQL Server 2008新特性——更改跟踪

在大型的数据库应用中,经常会遇到部分数据的脱机和多个数据库的合并问题.比如现在有一个全省范围使用的应用程序,每个市都部署了单独的相同的应用程序服务器和数据库服务器,每个月需要将全省所有市的数据全部汇总起来用于出全省的报表,这是一种很常见的数据库合并问题.再比如我们做了一个SmartClient的应用程序,每个客户端都有应用程序和数据库,另外还有一个中心数据库用于汇总所有客户端的数据.每个智能客户端上都可以对自己的数据库进行增删改查,一旦智能客户端连接到网络上时,系统就将客户端数据库中的数据更改全

SQL Server时间戳功能与用法详解

本文实例讲述了SQL Server时间戳功能与用法.分享给大家供大家参考,具体如下: 一直对时间戳这个概念比较模糊,相信有很多朋友也都会误认为:时间戳是一个时间字段,每次增加数据时,填入当前的时间值.其实这误导了很多朋友. 1.基本概念 时间戳:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制.存储大小为 8个字节. 每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加.该计数器是数据库时间戳.这 可以

SQL Server时间戳功能与用法详解_MsSql

本文实例讲述了SQL Server时间戳功能与用法.分享给大家供大家参考,具体如下: 一直对时间戳这个概念比较模糊,相信有很多朋友也都会误认为:时间戳是一个时间字段,每次增加数据时,填入当前的时间值.其实这误导了很多朋友. 1.基本概念 时间戳:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制.存储大小为 8个字节. 每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加.该计数器是数据库时间戳.这 可以

SQL SERVER 2000系统支持的跟踪函数

server|函数 你们大部分人可能已经在SQL SERVER中建立自己的用户定义函数(UDF),但是你知道么?微软公司已经集成了大量自己的UDFs,特别是在最新发布的SP3中.在这篇文章中 Baya Pavliashvili和Kevin Kline系统地研究了关于SQL SERVER跟踪部分的UDF.你们中的一些人也许想阅读以前SQL Server Professional的一篇关于传统UDFs的文章,比如Andrew Zanevsky's 2000年9月的专栏 ("Granting Wish

用COM自动服务扩展SQL Server的功能

server     SQL Server的T-SQL编程语言在数据存储和恢复方面功能强大,但在与SQL Server数据库之外的系统交互方面则功能较弱.然而,我们可以通过SQL Server内置的COM自动操作环境来克服这个限制,SQL Server内置的COM自动操作环境可以使用户在存储过程中自动操作COM对象. 在SQL Server 7.0和SQL Server 6.5中提供了7个扩展的存储过程,可以通过自己开发的或Office等现成的COM对象扩展SQL Server的功能.SQL S

sql server 数据库莫名其妙的更改

问题描述 sql server 数据库莫名其妙的更改 新手求指教 我用的vs2010 开发C/S项目,连接sql server 2008数据,用一条sql语句把包含外键的数据插入一张表中,莫名其妙的是其他字段的数据都能插入,唯有这个外键插入是-1,而且这种情况也只是偶尔发生!而且在其他电脑上测试,也是有的有这种情况,有的没有 我想如果是程序问题,应该每次插入时都会有出现这种现象啊! 难道是程序不稳定原因?如果不稳定该怎么测试出来呢?还是数据库的问题? 求高手指教~~~

SQL Server 7.0 入门(六)---建立存储过程体

server|存储过程 建立存储过程体 存储过程逻辑驻留在存储过程体中.一个存储过程体中可以包含任意条Transact SQL语句.下面的Transact SQL语句不能在任何存储过程体中出现: · CREATE DEFAULT · CREATE TRIGGER · CREATE PROCEDURE · CREATE VIEW · CREATE RULE 1. 局部变量 局部变量保持存储过程中间值.当一个值在存储过程中需要多次,或者某个查询的结果需要在随后的查询中使用时,需要使用局部变量.在这些