FIX: 작업 단계 실패 첫 경우 일괄 작업 빠진 중 메시지 3604 오류 INSERT

기술 자료 번역 기술 자료 번역
기술 자료: 295032 - 이 문서가 적용되는 제품 보기.
# 버그: 351328 (SHILOH_BUGS)
# 버그: 100729 (sqlbug_70)
모두 확대 | 모두 축소

이 페이지에서

현상

작업을 IGNORE_DUP_KEY 절 사용하여 고유 인덱스가 있는 테이블에 대해 단일 INSERT 문이 포함되어 있고 해당 INSERT 인덱스의 고유성 속성 위반하는 테이블에서 해당 행을 삽입하지 않았습니다. 작업 단계가 실패하고 작업 단계 기록에 다음 메시지가 표시됩니다.
중복 키가 무시되었습니다. [SQLSTATE 23000] (메시지 3604)입니다. 단계가 실패했습니다.
테이블의 UNIQUE INDEX IGNORE_DUP_KEY 함께 있기 때문에 INSERT 문은 무시해야 및 단계가 성공적으로 실행됩니다.

해결 방법

이 문제를 해결하려면 SQL Server 2000의 최신 서비스 팩을 구하십시오. 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
290211INF: SQL Server 2000의 최신 서비스 팩을 구하는 방법

해결 과정

방금 전에 3604 오류 단계가 실패하는 INSERT 문이 항상 성공적으로 (SELECT 1 같은) 실행하는 "더미" SELECT 문을 배치하면 성공합니다. "추가 정보" 절에 나와 있습니다.

현재 상태

Microsoft 문제는 이 문서의 시작 부분에 나열한 제품에서 문제를 확인했습니다. 이 문제는 SQL Server 2000 서비스 팩 1에서 처음 수정되었습니다.

추가 정보

문제를 재현하기 위해 단계

  1. pubs 데이터베이스에서 테이블 테스트 만들기 및 행을 삽입하려면 다음 스크립트 실행:
    USE pubs
    CREATE TABLE test(i int)
    CREATE UNIQUE INDEX uniq_t1_i on test(i) with IGNORE_DUP_KEY
    INSERT INTO test VALUES(1)
    					
  2. pubs 데이터베이스의 테이블에 테스트 행을 삽입하려면 T-SQL 작업을 만듭니다:
    INSERT INTO pubs..test values(1)
    					
  3. 작업을 실행하십시오. 작업이 실패하고 "현상" 절에 나열된 오류 작업 단계는 기록을 보여 줍니다.
  4. 성공적인 명령문에 있는 INSERT 추가하면 해당 3604 오류가 발생한 참고:
    INSERT INTO pubs..test values(1)
    INSERT INTO pubs..test values(2)
    					
    다음 오류 때문에 다시 단계가 실패할:
    중복 키가 무시되었습니다. [SQLSTATE 23000] (메시지 3604) [SQLSTATE HY007] 관련된 문이 준비되지 않았습니다 (오류 0). 단계가 실패했습니다.
  5. 그러나 우리는 성공적인 문에 있습니다 전에 3604 오류가 발생하는 INSERT 되며:
    insert pubs..t1 values(3)
    insert pubs..t1 values(1)
    					
    단계가 성공하고 다음 메시지가 표시됩니다.
    중복 키가 무시되었습니다. [SQLSTATE 23000] (메시지 3604)입니다. 단계가 성공했습니다.

속성

기술 자료: 295032 - 마지막 검토: 2003년 10월 28일 화요일 - 수정: 3.2
본 문서의 정보는 다음의 제품에 적용됩니다.
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 7.0 Standard Edition
키워드:?
kbmt kbbug kbfix kbsqlserv2000sp1fix KB295032 KbMtko
기계 번역된 문서
중요: 본 문서는 전문 번역가가 번역한 것이 아니라 Microsoft 기계 번역 소프트웨어로 번역한 것입니다. Microsoft는 번역가가 번역한 문서 및 기계 번역된 문서를 모두 제공하므로 Microsoft 기술 자료에 있는 모든 문서를 한글로 접할 수 있습니다. 그러나 기계 번역 문서가 항상 완벽한 것은 아닙니다. 따라서 기계 번역 문서에는 마치 외국인이 한국어로 말할 때 실수를 하는 것처럼 어휘, 구문 또는 문법에 오류가 있을 수 있습니다. Microsoft는 내용상의 오역 또는 Microsoft 고객이 이러한 오역을 사용함으로써 발생하는 부 정확성, 오류 또는 손해에 대해 책임을 지지 않습니다. Microsoft는 이러한 문제를 해결하기 위해 기계 번역 소프트웨어를 자주 업데이트하고 있습니다.

피드백 보내기

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com