SQL|SQL Server 多表数据增量获取和发布 2.2
数据库环境:
1、SQLServer 2008R2
2、SQLServer 代理打开
一、新建一个数据库
创建数据库 Incremental_DB
文章图片
image.png 二、创建俩张测试表 数据库脚本链接
--创建用户表
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]
三、实现数据变更捕获 一、对目标库显式启用CDC
USE Incremental_DB
GO
EXECUTE sys.sp_cdc_enable_db;
GO
查看是否启用CDC
SELECTis_cdc_enabled,CASE WHE is_cdc_enabled=0 THEN 'CDC功能禁用'ELSE 'CDC功能启用'END [描述]
FROMsys.databases
WHERE[name]='Incremental_DB'
创建成功后,会在测试库自动添加CDC用户和架构
文章图片
image.png 二、对目标库数据表显式启用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
语句执行成功后在系统表中生成俩张变化表
文章图片
新增表.png 数据库可编程性中增加俩个函数
文章图片
新增函数.png 同时SQLServer 代理中新增俩个作业
- capture(捕获作业)
- clean(清理作业)
文章图片
新增作业.png
文章图片
image.png
验证数据表是否启用CDC
USE Incremental_DB
--查看是否已启用:
SELECTname ,
is_tracked_by_cdc ,
CASE WHEN is_tracked_by_cdc = 0 THEN 'CDC功能禁用'
ELSE 'CDC功能启用'
END 描述
FROMsys.tables
WHEREOBJECT_ID IN(OBJECT_ID('Person'),OBJECT_ID('Department'))
四、禁用数据库或数据表CDC功能
禁用数据表CDC
--禁用人员表CDC功能
EXECUTE sys.sp_cdc_disable_table
@source_schema = N'dbo',
@source_name = N'Person',
@capture_instance = 'dbo_Person'
禁用后系统表中原来的dbo_Person_CT表被删除,函数删除等
文章图片
禁用后系统表截图.png
【SQL|SQL Server 多表数据增量获取和发布 2.2】禁用数据库CDC
EXEC sys.sp_cdc_disable_db
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- gitlab|gitlab 通过备份还原 admin/runner 500 Internal Server Error
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- mysql|InnoDB数据页结构
- 数据库|SQL行转列方式优化查询性能实践
- mysql中视图事务索引与权限管理
- MYSQL主从同步的实现
- MySQL数据库的基本操作