Erro de tabela: chave extra ou inválida

Microsoft.SQLServer.2005.Table_error__Extra_or_invalid_key_1_5_Rule (Rule)

Knowledge Base article:

Causas

Todas as linhas de dados em uma tabela (heap ou índice clusterizado) devem ter exatamente uma linha de índice correspondente em cada índice não clusterizado na tabela. Esse erro significa que um índice não clusterizado tem uma linha de índice que não corresponde a nenhuma linha de dados.

Será exibida a mensagem 8956, que identifica a linha de índice e suas chaves, e a linha de dados que a linha de índice considera correspondente. Também podem ser exibidos os erros 8951 e 8955.

Resoluções

HARDWARE FAILURE

Execute o diagnóstico de hardware e corrija quaisquer problemas. Além disso, examine os logs de sistema e de aplicativo do Microsoft Windows NT e o log de erros do SQL Server para saber se o erro ocorreu devido a uma falha de hardware. Corrija os problemas relacionados ao hardware.

Se houver problemas persistentes de inconsistência de dados, tente alternar diferentes componentes de hardware para isolar o problema. Verifique se o sistema está com a gravação em cache habilitada no controlador de disco. Se você suspeitar que esse é o caso, contate o fornecedor do hardware.

Por fim, talvez você considere válida a aquisição de um sistema de hardware completamente novo, além da reformatação das unidades de disco e da reinstalação do sistema operacional.

RESTORE FROM BACKUP

Se o problema não estiver relacionado ao hardware e se houver um backup limpo conhecido, restaure o banco de dados a partir do backup.

DBCC CHECKDB

Se não houver nenhum backup limpo disponível, execute o DBCC CHECKDB sem nenhuma cláusula de reparo para determinar a extensão do dano. O DBCC CHECKDB recomendará o uso de uma cláusula de reparo. Em seguida, execute o DBCC CHECKDB com a cláusula de reparo apropriada para reparar o dano.

CUIDADO: caso não esteja certo do efeito que o DBCC CHECKDB com uma cláusula de reparo terá em seus dados, contate o provedor de suporte antes de executar essa instrução.

Se a execução do DBCC CHECKDB com uma das cláusulas de reparo não corrigir o problema, contate o provedor de suporte.

Element properties:

TargetMicrosoft.SQLServer.2005.DBEngine
CategoryEventCollection
EnabledTrue
Event_ID8952
Event Source$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$
Alert GenerateTrue
Alert SeverityWarning
Alert PriorityNormal
RemotableTrue
Alert Message
Erro de tabela: chave extra ou inválida
{0}
Event LogApplication
CommentMom2005ID='{15DA894D-2F16-4A2A-ADF3-EB126DE4AD70}';MOM2005GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}

Member Modules:

ID Module Type TypeId RunAs 
_F6DA1507_12AF_11D3_AB21_00A0C98620CE_ DataSource Microsoft.Windows.EventProvider Microsoft.SQLServer.SQLDefaultAccount
GenerateAlert WriteAction System.Health.GenerateAlert Default

Source Code:

<Rule ID="Microsoft.SQLServer.2005.Table_error__Extra_or_invalid_key_1_5_Rule" Target="SQL2005Core!Microsoft.SQLServer.2005.DBEngine" Enabled="true" ConfirmDelivery="true" Remotable="true" Comment="Mom2005ID='{15DA894D-2F16-4A2A-ADF3-EB126DE4AD70}';MOM2005GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}">
<Category>EventCollection</Category>
<DataSources>
<DataSource ID="_F6DA1507_12AF_11D3_AB21_00A0C98620CE_" Comment="{F6DA1507-12AF-11D3-AB21-00A0C98620CE}" TypeID="Windows!Microsoft.Windows.EventProvider" RunAs="SQL!Microsoft.SQLServer.SQLDefaultAccount">
<ComputerName>$Target/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ComputerName>
<LogName>Application</LogName>
<Expression>
<And>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>PublisherName</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>$Target/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ServiceName$</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>EventDisplayNumber</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>8952</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
</And>
</Expression>
</DataSource>
</DataSources>
<WriteActions>
<WriteAction ID="GenerateAlert" TypeID="SystemHealth!System.Health.GenerateAlert">
<Priority>1</Priority>
<Severity>1</Severity>
<AlertMessageId>$MPElement[Name="Microsoft.SQLServer.2005.Table_error__Extra_or_invalid_key_1_5_Rule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue/>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>