本文共 2126 字,大约阅读时间需要 7 分钟。
数据库环境:
1、SQLServer 2008R2 2、SQLServer 代理打开创建数据库 Incremental_DB
--创建用户表CREATE TABLE [dbo].[Person]( [Id] [INT] IDENTITY(1,1) NOT NULL, [Name] [NVARCHAR](120) NULL, [Age] [INT] NULL, CONSTRAINT [PK_Demo] PRIMARY KEY CLUSTERED ( [Id] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]--创建部门表CREATE TABLE [dbo].[Department]( [Id] [INT] IDENTITY(1,1) NOT NULL, [Name] [NVARCHAR](50) NULL, CONSTRAINT [PK_Department] PRIMARY KEY CLUSTERED ( [Id] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]
USE Incremental_DBGOEXECUTE sys.sp_cdc_enable_db;GO
查看是否启用CDC
SELECT is_cdc_enabled,CASE WHE is_cdc_enabled=0 THEN 'CDC功能禁用'ELSE 'CDC功能启用'END [描述]FROM sys.databasesWHERE [name]='Incremental_DB'
创建成功后,会在测试库自动添加CDC用户和架构
USE Incremental_DBEXECUTE sys.sp_cdc_enable_table @source_schema = N'dbo'--架构名称 , @source_name = N'Department'--表名称 , @role_name = 'cdc_Admin'--会自动生成自定义 'cdc_Admin' 角色 如果不想控制访问角色,则@role_name必须显式设置为null , @capture_instance=NULLEXECUTE sys.sp_cdc_enable_table @source_schema = N'dbo'--架构名称 , @source_name = N'Person'--表名称 , @role_name = 'cdc_Admin'--会自动生成自定义 'cdc_Admin' 角色 如果不想控制访问角色,则@role_name必须显式设置为null , @capture_instance=NULL
语句执行成功后在系统表中生成俩张变化表
数据库可编程性中增加俩个函数
同时SQLServer 代理中新增俩个作业
clean(清理作业)
如果出现如下错误,请参考上一篇文章CDC注意事项第三点
验证数据表是否启用CDC
USE Incremental_DB--查看是否已启用:SELECT name , is_tracked_by_cdc , CASE WHEN is_tracked_by_cdc = 0 THEN 'CDC功能禁用' ELSE 'CDC功能启用' END 描述FROM sys.tablesWHERE OBJECT_ID IN(OBJECT_ID('Person'),OBJECT_ID('Department'))
禁用数据表CDC
--禁用人员表CDC功能EXECUTE sys.sp_cdc_disable_table @source_schema = N'dbo', @source_name = N'Person', @capture_instance = 'dbo_Person'
禁用后系统表中原来的dbo_Person_CT表被删除,函数删除等
禁用数据库CDC
EXEC sys.sp_cdc_disable_db
转载地址:http://urnea.baihongyu.com/