sql server cdc漏扫数据

SQL Server的CDC指的是"变更数据捕获"(Change Data Capture)。这是SQL Server数据库提供的一项功能,能够跟踪并记录对数据库表中数据所做的更改。这些更改包括插入、更新和删除操作。CDC可以捕获这些变更的详细信息,并使这些信息可用于进一步的处理,例如数据同步、数据仓库的更新或其他业务需求。

做了一个基础服务,定时扫cdc表的数据然后再数据同步到es上。运行一段时间后,发现es上的数据总是丢失变化。我想一个晚上,仍不知道自己错哪了。究竟是定时扫cdc的表拉取数据漏扫数据,还是数据处理出错呢,还是es同步数据出错呢?无奈日志打印内容太少了,只能增加日志重新部署生产观察了。

分析了一个晚上,终于找到原因了。

定时扫cdc的sql是类似这样

select * from table_CT with(nolock) where id>=@param order by id

扫到数据,处理完数据后把@param替换成上次扫的最大id,接着继续扫。

查询日志发现这条sql会漏扫数据。已知id是自增的,看着是没什么问题的。

with(nolock)是避免锁表,允许脏读(cdc表没有回滚的操作),第一眼看上去没什么问题。最读提前读到未提交的id,也没什么问题。

再细想,有问题,涉及到cdc如何捕获数据变更写入到变更表中。

把with(nolock)去掉,问题得到解决。

一看时间是凌晨4点钟,赶紧打电话给同事告诉他们这个好消息。

相关推荐
似水流年风萧兮26 分钟前
MySql按年月日自动创建分区存储过程
数据库·mysql·oracle
java1234_小锋33 分钟前
Redis是单线程还是多线程?
java·数据库·redis
臣妾写不来啊1 小时前
MySQL之having关键字
数据库·mysql
Ruyi_baobao2 小时前
MySQL -- 约束
数据库·mysql·oracle
L~river2 小时前
SQL刷题快速入门(二)
数据库·sql·mysql·算法·笔试·刷题
Faxxtty3 小时前
【MySQL】SQL菜鸟教程(一)
sql·mysql·oracle
费费开心一点3 小时前
数据库系统概论学习笔记
数据库·oracle
Lang_xi_3 小时前
mysql中创建计算字段
数据库·mysql
处女座_三月3 小时前
多并发发短信处理(头条项目-07)
java·前端·数据库·python