前言
多多点赞,会变好看!
多多留言,会变有钱!
一、CDC简介
变更数据捕获(Change Data Capture ,简称 CDC):记录 SQL Server 表的插入、更新和删除操作。开启cdc的源表在插入、更新和删除操作时会插入数据到日志表中。cdc通过捕获进程将变更数据捕获到变更表中,通过cdc提供的查询函数,可以捕获这部分数据。
二、开启CDC的必要条件
1、sqlserver 2008 以上版本
2、需要开启sql代理服务
3、磁盘要有足够的空间,保存日志文件
4、表必须要有主键或者是唯一索引
三、开启数据库CDC步骤
step1 开启数据库代理
SQL Server工具里启动代理:
文章来源:https://www.toymoban.com/news/detail-678492.html
服务里开启自动启动:文章来源地址https://www.toymoban.com/news/detail-678492.html
step2 开启数据库CDC脚本
IF EXISTS ( SELECT 1
FROM master.dbo.sysprocesses
WHERE program_name = N'SQLAgent - Generic Refresher')
BEGIN
SELECT @@SERVERNAME AS 'InstanceName', 1 AS 'SQLServerAgentRunning'
END
ELSE
BEGIN
SELECT @@SERVERNAME AS 'InstanceName', 0 AS 'SQLServerAgentRunning'
END
-- 查看数据库CDC开启状态
SELECT name, is_cdc_enabled FROM sys.databases WHERE is_cdc_enabled = 1;
-- 开启数据库CDC
USE BAFY;
EXECUTE sys.sp_cdc_enable_db;
-- 开启表CDC
EXEC sys.sp_cdc_enable_table
@source_schema = 'bzk',
@source_name = 'YLZL_BZFY_GYHSDC',
@role_name = null;
EXEC sys.sp_cdc_enable_table
@source_schema = 'bzk',
@source_name = 'YLZL_BZFY_JCXLNJZL',
@role_name = null;
EXEC sys.sp_cdc_enable_table
@source_schema = 'bzk',
@source_name = 'YLZL_BZFY_JXYXY',
@role_name = null;
EXEC sys.sp_cdc_enable_table
@source_schema = 'bzk',
@source_name = 'YLZL_BZFY_SXHDCX',
@role_name = null;
EXEC sys.sp_cdc_enable_table
@source_schema = 'bzk',
@source_name = 'YLZL_BZFY_YZXCB',
@role_name = null;
-- 查看表cdc开启状态
SELECT name, is_tracked_by_cdc FROM sys.tables WHERE name like 'YLZL_%';
到了这里,关于SQL server开启变更数据捕获(CDC)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!