SQL server开启变更数据捕获(CDC)

一、CDC简介

变更数据捕获(Change Data Capture ,简称 CDC):记录 SQL Server 表的插入、更新和删除操作。开启cdc的源表在插入、更新和删除操作时会插入数据到日志表中。cdc通过捕获进程将变更数据捕获到变更表中,通过cdc提供的查询函数,可以捕获这部分数据。

二、开启CDC的必要条件

1、sqlserver 2008 以上版本

2、需要开启sql代理服务

3、磁盘要有足够的空间,保存日志文件

4、表必须要有主键或者是唯一索引

三、开启数据库CDC步骤

step1 开启数据库代理

SQL Server工具里启动代理:

服务里开启自动启动:

step2 开启数据库CDC脚本

sql 复制代码
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_%';
相关推荐
繢鴻39 分钟前
数据库优化实战分享
数据库
Cachel wood1 小时前
后端开发:计算机网络、数据库常识
android·大数据·数据库·数据仓库·sql·计算机网络·mysql
暗离子跃迁2 小时前
达梦数据库单机部署dmhs同步复制(dm8->kafka)
linux·运维·数据库·分布式·学习·kafka·达梦数据库
LUCIAZZZ2 小时前
项目拓展-Apache对象池,对象池思想结合ThreadLocal复用日志对象
java·jvm·数据库·spring·apache·springboot
水木石画室2 小时前
Druid 连接池详解
数据库·mysql
yzpyzp2 小时前
gradle的 build时kaptDebugKotlin 处理数据库模块
android·数据库
软件2052 小时前
【redis——缓存雪崩(Cache Avalanche)】
数据库·redis·缓存
訾博ZiBo3 小时前
使用 Navicat 成功导入 2.73GB 超大 SQL 文件的实战经验(Win10,64GB内存)
数据库·mysql
小胖同学~3 小时前
SQL 增删改查 —— 笔记篇
服务器·数据库
梦兮林夕3 小时前
Docker + Gin + Gorm Gen:现代 Go Web 开发高效数据库实践
数据库·go·gin