
SQL Server 之 - 变更追踪 2
正如前面文章说道的,SQLServer 2008提供了两种实现变更追踪的功能,本部分主要讨论的是Change Tracking功能。
我们可以通过如下的步骤来激活和使用ChangeTracking功能:
1. 在数据库级别激活Change Tracking
使用下面的语句在数据库上激活该功能(或者在SSMS的属性弹出框中激活),它的两个参数分别表示变更信息的存活时间以及是否激活自动清除变更信息任务:
2. 在需要的表上激活Change Tracking
我们需要在每个想追踪变更的表上执行激活(需要注意的是,表必须具有主键才可以使用变更追踪功能),可以使用如下的语句或使用表属性弹出框:
其中参数TRACK_COLUMNS_UPDATED默认为False,因为维护列更新信息需要额外的存储开销。
3. 理解Change Tracking带来的开销
开启了Change Tracking会对数据库操作产生一些影响,我们可以从管理操作、DML操作及存储方面来查看它们具体的影响:
管理操作
DML操作
存储
在激活了该功能之后就到了使用它的时候了,在激活了该功能的数据库上会有一个版本计数器,然后每当在激活了变更追踪的表上执行DML操作的时候都会产生一个新的Version号与之关联,在某种程度上变更追踪的版本号与rowversion数据类型有些相似。
现在我们可以很容易的想象如何使用变更追踪的:
首先应用程序从数据库做一次初始数据的加载
然后获取当时的Version号并记录一下以作为下次数据抽取的起始点
然后当下次应用程序需要从数据库做增量数据抽取的时候,提供上次记录下来的Version号并仅仅加载新的改动
如果很不幸的,应用程序在上次增量完成之后到下次增量抽取之间变动信息被清除了,那么应用程序不得不重新做一次全数据加载以防止数据不一致
数据库提供了一下的函数来实现上面提到的功能:
1. CHANGE_TRACKING_CURRENT_VERSION()
获取当下最新的变更的Version号
2. CHANGETABLE(CHANGES…)
该行集函数返回变更信息,它接受表明及Version号作为参数,然后从内部追踪变更信息的表中为该用户表返回从提供了Version号之后发生的所有变更信息
3. CHANGE_TRACKING_MIN_VALID_VERSION()
该函数需要一个表的object_id,然后返回当前数据库中最小的有效Version号。应用程序在每次做增量抽取之前,应该判断上次加载的Version号是否小于当前有效的Version号,如果是的话意味着有些变更信息因为某些原因已经被清除掉了,这时候必须做一次全数据加载
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
用 SQL 生成逆向回滚 SQL:数据操作的 “后悔药” 指南 在数据库操作中,误删数据、错改字段或误执行批量更新等问题时有发生。 ...
2025-07-14如何考取数据分析师证书:以 CDA 为例 在数字化浪潮席卷各行各业的当下,数据分析师已然成为企业挖掘数据价值、驱动决策的 ...
2025-07-14t检验与Wilcoxon检验的选择:何时用t.test,何时用wilcox.test? t 检验与 Wilcoxon 检验的选择:何时用 t.test,何时用 wilcox. ...
2025-07-14AI 浪潮下的生存与进阶: CDA数据分析师—开启新时代职业生涯的钥匙(深度研究报告、发展指导白皮书) 发布机构:CDA数据科 ...
2025-07-13LSTM 模型输入长度选择技巧:提升序列建模效能的关键 在循环神经网络(RNN)家族中,长短期记忆网络(LSTM)凭借其解决长序列 ...
2025-07-11CDA 数据分析师报考条件详解与准备指南 在数据驱动决策的时代浪潮下,CDA 数据分析师认证愈发受到瞩目,成为众多有志投身数 ...
2025-07-11数据透视表中两列相乘合计的实用指南 在数据分析的日常工作中,数据透视表凭借其强大的数据汇总和分析功能,成为了 Excel 用户 ...
2025-07-11尊敬的考生: 您好! 我们诚挚通知您,CDA Level I和 Level II考试大纲将于 2025年7月25日 实施重大更新。 此次更新旨在确保认 ...
2025-07-10BI 大数据分析师:连接数据与业务的价值转化者 在大数据与商业智能(Business Intelligence,简称 BI)深度融合的时代,BI ...
2025-07-10SQL 在预测分析中的应用:从数据查询到趋势预判 在数据驱动决策的时代,预测分析作为挖掘数据潜在价值的核心手段,正被广泛 ...
2025-07-10数据查询结束后:分析师的收尾工作与价值深化 在数据分析的全流程中,“query end”(查询结束)并非工作的终点,而是将数 ...
2025-07-10CDA 数据分析师考试:从报考到取证的全攻略 在数字经济蓬勃发展的今天,数据分析师已成为各行业争抢的核心人才,而 CDA(Certi ...
2025-07-09【CDA干货】单样本趋势性检验:捕捉数据背后的时间轨迹 在数据分析的版图中,单样本趋势性检验如同一位耐心的侦探,专注于从单 ...
2025-07-09year_month数据类型:时间维度的精准切片 在数据的世界里,时间是最不可或缺的维度之一,而year_month数据类型就像一把精准 ...
2025-07-09CDA 备考干货:Python 在数据分析中的核心应用与实战技巧 在 CDA 数据分析师认证考试中,Python 作为数据处理与分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 检验:数据趋势与突变分析的有力工具 在数据分析的广袤领域中,准确捕捉数据的趋势变化以及识别 ...
2025-07-08备战 CDA 数据分析师考试:需要多久?如何规划? CDA(Certified Data Analyst)数据分析师认证作为国内权威的数据分析能力认证 ...
2025-07-08LSTM 输出不确定的成因、影响与应对策略 长短期记忆网络(LSTM)作为循环神经网络(RNN)的一种变体,凭借独特的门控机制,在 ...
2025-07-07统计学方法在市场调研数据中的深度应用 市场调研是企业洞察市场动态、了解消费者需求的重要途径,而统计学方法则是市场调研数 ...
2025-07-07CDA数据分析师证书考试全攻略 在数字化浪潮席卷全球的当下,数据已成为企业决策、行业发展的核心驱动力,数据分析师也因此成为 ...
2025-07-07