Attribute | 值 |
---|---|
产品名称 | SQL Server |
事件 ID | 2512 |
事件源 | MSSQLSERVER |
组件 | SQLEngine |
符号名称 | DBCC_DUPLICATE_KEYS |
消息正文 | 表错误:对象 ID O_ID,索引 ID I_ID,分区 ID PN_ID,分配单元 ID A_ID (类型为 TYPE)。 页 P_ID1 槽 SLOT1 和页 P_ID2 槽 SLOT2 中的重复键。 |
两个指定的槽具有相同的键,其中包含任何 uniqueifier。
运行硬件诊断并更正任何问题。 也可以通过检查 Microsoft Windows 系统和应用程序日志以及 SQL Server 错误日志来查看是否存在由硬件故障导致的错误。 修复日志中包含的所有与硬件相关的问题。
如果持续遇到数据损坏问题,请尝试分别换下不同的硬件组件以确定问题所在。 进行检查以确保系统未启用磁盘控制器上的写缓存。 如果怀疑写入缓存是问题起因,请与硬件供应商联系。
最后,您可能会发现,切换到全新的硬件系统是解决问题的极佳途径。 此切换操作可能包括重新格式化磁盘驱动器和重新安装操作系统。
如果出现的问题与硬件无关,并且您确信有可用的干净备份,请从备份中还原数据库。
如果不存在干净的可用备份,请运行不带 REPAIR 子句的 DBCC CHECKDB 以确定损坏程度。 建议使用 DBCC CHECKDB 的 REPAIR 子句。 接下来,请运行带适当 REPAIR 子句的 DBCC CHECKDB 修复损坏的数据。
注意
如果您不确定运行带有 REPAIR 子句的 DBCC CHECKDB 会对数据造成何种影响,请在运行该语句前与您的主要支持提供商联系。
如果运行具有 REPAIR 子句的 DBCC CHECKDB 无法解决存在的问题,请与主要支持提供商联系。
如果记录为虚影或者索引不唯一,则 DBCC 可以通过重新生成索引来修复此问题。 否则,REPAIR 在必要时将删除页 P_ID2 上的槽 SLOT2,或者将该槽标记为虚影。