SQLServer 2008 CDC实现数据变更捕获使用图文详解

2019-10-07 20:18:01王振洲

结果如图:



可以看到在创建的同时,也创建了两个作业: cdc.AdventureWorks_cleanup和cdc.AdventureWorks_capture

也可以看到多了一个角色CDC_ADMIN,是在上面语句中动态创建的:



按照上面步骤把另外两个表也开启了:


复制代码</div> <div> <p align="left">USE AdventureWorks;</p> <p align="left">GO</p> <p align="left">EXECUTE sys.sp_cdc_enable_table</p> <p align="left"> @source_schema= N'Person'</p> <p align="left"> , @source_name= N'ADDRESS'</p> <p align="left"> , @role_name= N'cdc_Admin'--可以自动创建</p> <p align="left"> , @capture_instance=DEFAULT</p> <p align="left">GO</p> <p align="left">EXECUTE sys.sp_cdc_enable_table</p> <p align="left"> @source_schema= N'Person'</p> <p align="left"> , @source_name= N'Contact'</p> <p align="left"> , @role_name= N'cdc_Admin'--可以自动创建</p> <p align="left"> , @capture_instance=DEFAULT</p> <p align="left">GO</p> <p>

可以从系统表中看到:




了3个表,并且是刚才开启CDC功能的表。现在来检查是否开启成功:


复制代码</div> <p align="left">SELECT name ,</p> <p align="left"> is_tracked_by_cdc ,</p> <p align="left"> CASE WHEN is_tracked_by_cdc = 0 THEN 'CDC功能禁用'</p> <p align="left"> ELSE 'CDC功能启用'</p> <p align="left"> END 描述</p> <p align="left">FROM sys.tables</p> <p align="left">WHERE OBJECT_ID IN(OBJECT_ID('HumanResources.Department'),</p> <p align="left"> OBJECT_ID('Person.ADDRESS'),</p> <p align="left"> OBJECT_ID('Person.Contact'))</p> <p>

结果如下:



步骤三:检验: 下面来改动数据:


然后把表中的数据复制一份:


复制代码</p> <p align="left">INSERT INTO HumanResources.Department</p> <p align="left"> (Name ,</p> <p align="left"> GroupName ,</p> <p align="left"> ModifiedDate </p> <p align="left"> )</p> <p align="left"> SELECT Name + '1' ,</p> <p align="left"> GroupName + '1' ,</p> <p align="left"> GETDATE()ModifiedDate</p> <p> FROM HumanResources.Department</p> <p>

相关文章 大家在看