FIX: 여러 OR 함께 CONTAINSTABLE 함수를 사용하면 스케줄러는 응답하지 않는 오류가 발생할 수 있습니다, SQL Server 2008 또는 SQL Server 2008 R2 AND 조건자

기술 자료 번역 기술 자료 번역
기술 자료: 2344600 - 이 문서가 적용되는 제품 보기.
Microsoft는 Microsoft SQL Server 2008 수정을 다운로드할 수 있는 파일로 배포합니다. 수정 프로그램은 계속 누적되는 형태입니다 때문에 핫픽스가 모두 각 새 릴리스에 포함된 이전 SQL Server 2008 포함된 모든 보안 릴리스의 수정.Microsoft는 Microsoft SQL Server 2008 배포하는 또는 SQL Server 2008 R2 다운로드 가능한 파일로 해결합니다. 수정 프로그램은 계속 누적되는 형태입니다 때문에 핫픽스가 모두 각 새 릴리스에 포함된 이전 SQL Server 2008 또는 SQL Server 2008 R2 포함된 모든 보안 릴리스의 수정.
모두 확대 | 모두 축소

이 페이지에서

현상

다음과 같은 경우를 생각해 볼 수 있습니다.:
  • 사용하는 전체 텍스트 검색 쿼리를 사용하는 경우CONTAINSTABLE많이 사용하는 함수또는Microsoft SQL Server 2008 SQL Server 2008 R2 조건의 조건자 예를 들어, 다음 50이 있습니다.작업:
    Declare @Keywords varchar(4000) = NULL
    
    set @Keywords= N'((((((((((((((((((((((((((((((((((((((((((((((((((((
    ("TOKarchitect" OR "architectural") 
    AND ("TOKengineer" OR "engineer")) 
    AND "gineer") AND ("TOKmechanical" OR "Mechanical")) 
    AND ("TOKengineer" OR "Engineering")) 
    AND ("TOKelectronic" OR "Electronics")) AND ("TOKengineer" OR "Engineer")) AND ("TOKelectronic" OR "Electronics")) AND ("TOKengineer" OR "Engineering")) AND ("TOKelectric" OR "Electrical")) AND ("TOKengineer" OR "Engineer")) AND ("TOKelectric" OR "Electrical")) AND ("TOKengineer" OR "Engineering")) AND ("TOKcontrol" OR "Control")) AND ("TOKsystem" OR "Systems")) AND ("TOKengineer" OR "Engineer")) AND ("TOKproject" OR "Project")) AND ("TOKmanager" OR "Manager")) AND ("TOKengineer" OR "Engineering")) AND "Scheme") AND ("TOKmanufacture" OR "Manufacturing")) AND ("TOKengineer" OR "Engineer")) AND ("TOKmetallurgist" OR "Metallurgy")) AND ("TOKmetallurgist" OR "Metallurgist")) AND ("TOKprocess" OR "Process")) AND ("TOKTechnology" OR "Technology")) AND ("TOKproduct" OR "Production")) AND ("TOKengineer" OR "Engineer")) AND ("TOKQuality" OR "Quality")) AND ("TOKengineer" OR "Engineer")) AND ("TOKQuality" OR "Quality")) AND ("TOKcontrol" OR "Control")) AND ("TOKengineer" OR "Engineer")) AND "Mechatronics") AND ("TOKcivil" OR "Civil")) AND ("TOKengineer" OR "Engineer")) AND ("TOKcivil" OR "Civil")) AND ("TOKengineer" OR "Engineering")) AND ("TOKdesign" OR "Design")) AND ("TOKengineer" OR "Engineering")) AND ("TOKdesign" OR "Design")) AND ("TOKengineer" OR "Engineer")) AND ("TOKgraduate" OR "Graduate")) AND ("TOKengineer" OR "Engineer")) AND ("TOKgraduate" OR "Graduate")) AND ("TOKengineer" OR "engineering")) AND ("TOKengineer" OR "Engineering")) AND ("TOKgraduate" OR "Graduate")) AND ") ANDNOT (") AND ("TOKRecruitment" OR "Recruitment")) AND ("TOKconsultant" OR "consultant")) AND ("TOKtrainee" OR "trainee")) AND ("TOKRecruitment" OR "recruitment"))'
    
    select * from CONTAINSTABLE(test_table, *, @keywords, 1000) 
  • 쿼리를 실행합니다.
이 시나리오에서는 스케줄러는 응답하지 않는 오류가 발생할 수 있습니다. 또한 SQL Server 2008 또는 SQL Server 2008 R2 응용 프로그램 로그 폴더 덤프가 파일 생성되어 SQL Server 오류 로그 파일에 다음과 같은 오류가 기록됩니다.
<time stamp=""></time>'dbghelp.dll을' 버전 '4.0.5' 서버 사용
<time stamp=""></time>서버 *** spid 0 스레드 컨텍스트를 가져올 수 없습니다
<time stamp=""></time>서버 *
*******************************************************************************
<time stamp=""></time>서버 *
<time stamp=""></time>* 서버 스택 덤프가 시작:
<time stamp=""></time>서버 *<time></time>spid<spid></spid>
<time stamp=""></time>서버 *
<time stamp=""></time>* 서버 스케줄러는 응답하지 않음
<time stamp=""></time>서버 *
<time stamp=""></time>서버 *
*******************************************************************************
<time stamp=""></time>스택 덤프 서명 0x000000000000030D 서버가 있습니다.
<time stamp=""></time>서버 프로세스 외부 덤프 반환 코드 0x20000001. 덤프 외부 프로세스에서 오류를 반환했습니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 75187 ms. 프로세스 사용률이 98 %62 ms. 시스템 유휴 %0. 간격: 76403 ms입니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 145250 ms. 프로세스 사용률이 98 %125 ms. 시스템 유휴 %0. 간격: 148417 ms입니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 205515 ms. 프로세스 사용률이 98 %171 ms. 시스템 유휴 %0. 간격: 209729 ms입니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 266343 ms. 프로세스 사용률이 98 %218 ms. 시스템 유휴 %0. 간격: 271588 ms입니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 325156 ms. 프로세스 사용률이 97 %234 ms. 시스템 유휴 %0. 간격: 333671 ms입니다.
<time stamp=""></time>서버 프로세스 0: 0: 0 (0xf94) 작업자 0x00000000817481A0 아닌 응답하지 스케줄러 0 것으로 나타납니다. 스레드 생성 시간: 12925321224306. 대략적인 스레드 CPU 사용: 커널 사용자 386000 ms. 프로세스 사용률이 97 %296 ms. 시스템 유휴 %0. 간격: 396370 ms입니다.

원인

SQL Server 2008 또는 SQL Server 2008 R2 스케줄러가 제대로 해제하지 않기 때문에 이 문제가 발생합니다.

해결 방법

누적 업데이트 정보

SQL Server 2008 R2

이 문제에 대한 수정 프로그램은 먼저 누적 업데이트 5 릴리스되었습니다. SQL Server 2008 R2 누적 업데이트 패키지를 구하는 방법에 대한 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
2438347SQL Server 2008 R2 누적 업데이트 패키지 5
참고빌드 누적되는 형태이므로 새로운 각 수정 릴리스 핫픽스가 모두 포함하며 이전 SQL Server 2008 R2 포함된 모든 보안 릴리스의 수정. 이 핫픽스가 포함된 최신 수정 릴리스를 적용하는 것이 좋습니다. 위 핫픽스 관련 추가 정보는 다음 Microsoft 기술 문서를 참조하십시오.:
981356SQL Server 2008 R2 SQL Server 2008 R2 출시된 이후에 릴리스된 빌드

SQL Server 2008 서비스 팩 1

이 문제에 대한 수정 프로그램은 SQL Server 2008 서비스 팩 1용 누적 업데이트 10에서 에서 처음 릴리스되었습니다. 이 누적 업데이트 패키지에 대한 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
2279604SQL Server 2008 서비스 팩 1에서 10 누적 업데이트 패키지
참고빌드 누적되는 형태이므로 새로운 각 수정 릴리스 핫픽스가 모두 포함하며 이전 SQL Server 2008 포함된 모든 보안 릴리스의 수정. 이 핫픽스가 포함된 최신 수정 릴리스를 적용하는 것이 좋습니다. 위 핫픽스 관련 추가 정보는 다음 Microsoft 기술 문서를 참조하십시오.:
970365SQL Server 2008 서비스 팩 1 릴리스 이후에 릴리스된 SQL Server 2008 빌드
Microsoft SQL Server 2008 핫픽스는 특정 SQL Server 서비스 팩은 만들 수 있습니다. SQL Server 2008 서비스 팩 1을 설치하는 데 SQL Server 2008 서비스 팩 1 핫픽스를 적용해야 합니다. 기본적으로 SQL Server 서비스 팩에서 제공되는 모든 핫픽스는 다음 SQL Server 서비스 팩에 포함됩니다.

SQL Server 2008 서비스 팩 2

이 문제에 대한 수정 프로그램은 먼저 SQL Server 2008 서비스 팩 2는 누적 업데이트 1 릴리스되었습니다. 이 누적 업데이트 패키지에 대한 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
2289254SQL Server 2008 서비스 팩 2용 누적 업데이트 1
참고빌드 누적되는 형태이므로 새로운 각 수정 릴리스 핫픽스가 모두 포함하며 이전 SQL Server 2008 포함된 모든 보안 릴리스의 수정. 이 핫픽스가 포함된 최신 수정 릴리스를 적용하는 것이 좋습니다. 위 핫픽스 관련 추가 정보는 다음 Microsoft 기술 문서를 참조하십시오.:
2402659SQL Server 2008 서비스 팩 2 릴리스 이후에 릴리스된 SQL Server 2008 빌드

해결 과정

이 문제를 해결하려면 전체 텍스트 검색 동의어 사전에서를 동의어 조건자의 정의할 수 있습니다.

이 작업을 수행할 수 있는FORMSOF함께 작동하는 경우동의어 사전값 를 클릭한 다음 매개 변수로 모든 키워드를 추가하십시오.

"현상" 절에 설명되어 있는 예제 업데이트된 버전의 예제 쿼리는 다음과 같습니다.
Select * from test_table where Contains(*,'FORMSOF (THESAURUS,"architectural","engineer","Mechanical","Engineering","Electronics","Engineer","Electrical","Control","Systems","Project","Manager","Manufacturing","Metallurgy","Metallurgist","Process",”Design”,"Technology","Production","Quality","Control","Civil","Graduate","Recruitment","consultant","trainee","recruitment")')

현재 상태

Microsoft는 "본 문서의 정보는 다음의 제품에 적용됩니다." 절에 나열된 Microsoft 제품에서 이 문제가 발생하는 것을 확인했습니다..

참조

자세한 내용은 해당CONTAINSTABLE기능을 보려면 다음 MSDN Microsoft 개발자 네트워크 웹 사이트를 방문하십시오.
CONTAINSTABLE 함수에 대한 일반 정보
SQL Server의 증분 서비스 모델에 대한 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
935897보고된 문제에 대한 핫픽스를 제공하는 SQL Server 팀으로부터 증분 서비스 모델을 사용합니다
SQL Server 업데이트의 명명 스키마에 대한 자세한 내용은 Microsoft 기술 자료의 다음 문서를 참조하십시오.
822499Microsoft SQL Server 소프트웨어 업데이트 패키지의 새 명명 스키마
소프트웨어 업데이트 용어에 대한 자세한 문서를 보려면 Microsoft 기술 자료에 있는 다음 문서를 참조하십시오.:
824684Microsoft 소프트웨어 업데이트를 설명하는 데 사용되는 표준 용어에 대한 설명

속성

기술 자료: 2344600 - 마지막 검토: 2010년 12월 20일 월요일 - 수정: 4.0
본 문서의 정보는 다음의 제품에 적용됩니다.
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Service Pack 1
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Standard Edition for Small Business
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Standard Edition for Small Business
  • Microsoft SQL Server 2008 R2 Workgroup
키워드:?
kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2344600 KbMtko
기계 번역된 문서
중요: 본 문서는 전문 번역가가 번역한 것이 아니라 Microsoft 기계 번역 소프트웨어로 번역한 것입니다. Microsoft는 번역가가 번역한 문서 및 기계 번역된 문서를 모두 제공하므로 Microsoft 기술 자료에 있는 모든 문서를 한글로 접할 수 있습니다. 그러나 기계 번역 문서가 항상 완벽한 것은 아닙니다. 따라서 기계 번역 문서에는 마치 외국인이 한국어로 말할 때 실수를 하는 것처럼 어휘, 구문 또는 문법에 오류가 있을 수 있습니다. Microsoft는 내용상의 오역 또는 Microsoft 고객이 이러한 오역을 사용함으로써 발생하는 부 정확성, 오류 또는 손해에 대해 책임을 지지 않습니다. Microsoft는 이러한 문제를 해결하기 위해 기계 번역 소프트웨어를 자주 업데이트하고 있습니다.
이 문서의 영문 버전 보기:2344600

피드백 보내기

 

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