MSSQL 2014: 테이블 오류: 테이블에서 행의 인덱스에 키가 없거나 잘못되었습니다.

Microsoft.SQLServer.2014.Table_error__Table_missing_or_invalid_key_in_index_for_the_row__1_5_Rule (Rule)

테이블 내 모든 데이터 행(힙 또는 클러스터형 인덱스)은 그 테이블의 모든 비클러스터형 인덱스에서 정확히 하나의 일치하는 인덱스 행을 가져야 합니다. 이 오류는 비클러스터형 인덱스에 인덱스 행이 없음을 나타냅니다.

Knowledge Base article:

원인

테이블 내 모든 데이터 행(힙 또는 클러스터형 인덱스)은 그 테이블의 모든 비클러스터형 인덱스에서 정확히 하나의 일치하는 인덱스 행을 가져야 합니다. 이 오류는 비클러스터형 인덱스에 인덱스 행이 없음을 나타냅니다.

없어진 인덱스 행의 데이터 행 및 해당 키를 식별하는 8955 메시지가 함께 나타납니다. 8952 및 8956 오류도 함께 나타날 수 있습니다.

해결 방법

하드웨어 오류

하드웨어 진단을 실행하여 문제가 있으면 이를 해결하십시오. 또한 Microsoft Windows NT 시스템 및 응용 프로그램 로그와 SQL Server 오류 로그를 확인하여 이 오류가 하드웨어 오류로 인해 발생한 것인지 확인합니다. 하드웨어 관련 문제가 있으면 해결하십시오.

데이터 손상 문제가 지속되면 다른 하드웨어 구성 요소로 교체하여 문제를 해결하십시오. 디스크 컨트롤러에서 쓰기 캐싱을 사용하도록 설정하지 않았는지 확인합니다. 이것이 문제라고 생각되면 하드웨어 공급업체에 문의하십시오.

마지막으로, 디스크 드라이브를 다시 포맷하고 운영 체제를 다시 설치하는 등 새 하드웨어 시스템으로 완전히 전환하는 것이 도움이 될 수 있습니다.

백업에서 복원

하드웨어 관련 문제가 아니면 정상적인 백업(있는 경우)을 사용하여 데이터베이스를 복원하십시오.

DBCC CHECKDB

문제가 없는 백업을 사용할 수 없는 경우 복구 절 없이 DBCC CHECKDB를 실행하여 손상 범위를 확인합니다. DBCC CHECKDB에서 사용할 복구 절을 제시해 줍니다. 그러면 해당 복구 절을 사용해서 DBCC CHECKDB를 실행하여 손상을 복구하십시오.

주의: DBCC CHECKDB에 복구 절을 사용할 때 데이터에 어떤 영향이 있는지 잘 모를 경우 이 명령문을 실행하기 전에 주 지원 공급자에게 문의하십시오.

복구 작업을 수행하면 인덱스가 다시 작성됩니다. 복구 절을 사용하여 DBCC CHECKDB를 실행해도 문제가 해결되지 않을 경우 주 지원 공급자에게 문의하십시오.

페이지가 IAM 페이지인 경우 복구를 수행하면 일부분인 IAM 체인이 다시 만들어져 페이지가 제거됩니다. 그렇지 않으면, 페이지 할당이 취소됩니다.

재정의 가능한 매개 변수

이름

설명

기본값

사용

 

알림 생성

 

우선 순위

 

1

심각도

 

1

Element properties:

TargetMicrosoft.SQLServer.2014.DBEngine
CategoryEventCollection
EnabledTrue
Event_ID8951
Event Source$Target/Property[Type="SQL2014Core!Microsoft.SQLServer.2014.DBEngine"]/ServiceName$
Alert GenerateTrue
Alert SeverityWarning
Alert PriorityNormal
RemotableTrue
Alert Message
MSSQL 2014: 테이블 오류: 테이블에서 행의 인덱스에 키가 없거나 잘못되었습니다.
{0}
Event LogApplication
CommentMom2014ID='{E558B134-08BB-4D47-A655-D4E83D0D8D02}';MOM2014GroupID={467ECC75-C5DA-42BD-955C-A73BBB51AF74}

Member Modules:

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

Source Code:

<Rule ID="Microsoft.SQLServer.2014.Table_error__Table_missing_or_invalid_key_in_index_for_the_row__1_5_Rule" Target="SQL2014Core!Microsoft.SQLServer.2014.DBEngine" Enabled="true" ConfirmDelivery="true" Remotable="true" Comment="Mom2014ID='{E558B134-08BB-4D47-A655-D4E83D0D8D02}';MOM2014GroupID={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">
<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="SQL2014Core!Microsoft.SQLServer.2014.DBEngine"]/ServiceName$</Value>
</ValueExpression>
</SimpleExpression>
</Expression>
<Expression>
<SimpleExpression>
<ValueExpression>
<XPathQuery>EventDisplayNumber</XPathQuery>
</ValueExpression>
<Operator>Equal</Operator>
<ValueExpression>
<Value>8951</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.2014.Table_error__Table_missing_or_invalid_key_in_index_for_the_row__1_5_Rule.AlertMessage"]$</AlertMessageId>
<AlertParameters>
<AlertParameter1>$Data/EventDescription$</AlertParameter1>
</AlertParameters>
<Suppression>
<SuppressionValue/>
</Suppression>
</WriteAction>
</WriteActions>
</Rule>