日期:2014-05-18 浏览次数:20636 次
SQL SERVER 2008 异步捕获表数据修改 写的不对的地方请各位指正,写的也比较乱。讲究这看吧。^ ^ /* SQL SERVER 2008 异步捕获表数据修改 SQL server 2008为异步跟踪所有发生在用户表上的数据修改提供了内建的方法, 而不需要编写自定义的触发器或者查询,变更数据捕获拥有最小性能开销,可以 用于其它数据源的持续更新,例如,将OLTP数据库中的数据变更迁移到数据仓库 数据库.下面我们演示该功能. */ /* 1 建立测试数据库 */ IF NOT EXISTS (SELECT NAME FROM SYS.databases WHERE name='CDC_TEST_DB') BEGIN CREATE DATABASE CDC_TEST_DB END /* 2 在把CDC增加到CDC_TEST_DB数据库的表中,首先应该验证数据库是否启用了数据 捕获 */ --验证是否开启 SELECT IS_CDC_ENABLED FROM SYS.databases WHERE name='CDC_TEST_DB' /* IS_CDC_ENABLED -------------- 0 (1 行受影响) */ --启用数据变更,在CDC_TEST_DB数据库中执行SYS.SP_CDC_ENABLE_DB存储过程: USE CDC_TEST_DB GO EXEC sys.SP_CDC_ENABLE_DB GO /* CDC_TEST_DB开启数据捕获后,你将会在CDC_TEST_DB->安全性->架构下面看到新 建立了一个CDC架构. 同样在CDC_TEST_DB会建立一些CDC架构的下的系统表: cdc.captured_columns 返回指定的跟踪列 cdc.change_tables 返回启用CDC的表.使用sys.sp_cdc_help_change_data_capture比直接查询好. cdc.ddl_history 返回每个表再启用CDC后的DDL变更.可以使用sys.sp_cdc_get_ddl_history代替查询该表. cdc.index_columns 返回启用CDC的表的相关索引列.同样用sys.sp_cdc_help_change_data_capure来获取比较好. cdc.lsn_time_mapping 为每个在更改表中存在行的事务返回一行.该表用于在日志序列号(LSN) 提交值和提交事务的时间之间建立映射. 要避免直接查询该表,使用sys.fn_cdc_map_lsn_to_time和sys.fn_cdc_map_time_to_lsn函数. */ --下面再验证看看是否已经开启数据库开启 SELECT IS_CDC_ENABLED FROM SYS.databases WHERE name='CDC_TEST_DB' /* IS_CDC_ENABLED -------------- 1 (1 行受影响) */ ...... 内容比较多下面的地址阅读 博文地址:http://blog.csdn.net/ldslove/archive/2010/05/20/5612248.aspx */