注册 登录
编程论坛 SQL Server论坛

sqlserver 数据库开启CDC数据变更捕获后,做数据库恢复时报错无法升级启用变更数据捕获数据库,应该怎么处理呢?

周恩兵 发布于 2022-03-18 11:16, 1283 次点击
===================================

还原数据库“AIS2019PXJT”时失败。 (Microsoft.SqlServer.Management.RelationalEngineTasks)

------------------------------
程序位置:

   在 Microsoft.SqlServer.Management.RelationalEngineTasks.RestoreDatabaseTaskFormComponent.PerformTask(ITaskExecutionContext context)
   在 Microsoft.SqlServer.Management.RelationalEngineTasks.RestoreDatabaseTaskFormComponent.Perform(ITaskExecutionContext context)
   在 Microsoft.SqlServer.Management.TaskForms.TaskExecutionManager.ExecuteTaskSequence(ISfcScriptCollector collector)

===================================

System.Data.SqlClient.SqlError: 无法升级启用了变更数据捕获的数据库 'AIS2019PXJT' 的元数据。执行操作 'alter cdc.change_tables index change_tables_unique_idx with (drop_existing = on)' 时失败。返回的错误为 4922: 'line 102, state 9, 由于一个或多个对象访问此列,ALTER TABLE ALTER COLUMN column_id 失败。'。请使用此操作和错误来确定失败的原因并重新提交请求。 (Microsoft.SqlServer.SmoExtended)

------------------------------
有关帮助信息,请单击: http://go.((SQL14_RTM).140220-1752)&LinkId=20476

------------------------------
程序位置:

   在 Microsoft.SqlServer.Management.Smo.RestorePlan.Execute()
   在 Microsoft.SqlServer.Management.RelationalEngineTasks.RestoreDatabaseTaskFormComponent.PerformTask(ITaskExecutionContext context)
0 回复
1