FIX: xp_sendmail 있는 COMPUTE 절을 원인 함께 액세스 위반을 사용

기술 자료 번역 기술 자료 번역
기술 자료: 819955 - 이 문서가 적용되는 제품 보기.
이 문서가 보관되었습니다. "그대로" 제공되었으며, 업데이트가 되지 않을 것입니다.
# 버그: 469145 (SHILOH_BUGS)
모두 확대 | 모두 축소

이 페이지에서

현상

다음 조건이 모두 충족될 때 xp_sendmail 확장 저장된 프로시저를 호출하여 처리된 액세스 위반이 발생할 수 있습니다.
  • xp_sendmail 호출이 @ query 사용해야 레코드 보내기 위해 매개 변수.
  • 쿼리 @ query 전달된 COMPUTE 절이 매개 변수가 포함되어야 합니다.
  • 쿼리는 행이 반환해야 합니다.
다음은 이 문제가 발생할 수 있는 쿼리:
 EXEC master..xp_sendmail 
 @recipients = 'recipient_email_address',
 @message = 'Total Sum of Job ID' ,
 @subject = 'Compute Sum',
 @width = 133 ,
 @query = 'SELECT emp_id, fname, minit, lname, job_id, job_lvl, pub_id FROM pubs.dbo.employee WHERE 1=0 COMPUTE SUM (job_id)'
적은 수의 이후 SQL Server 2000 서비스 팩 3 핫픽스 릴리스 경우에만 영향을 회귀 노트 이 문제가 있습니다. 이 문제는 SQL Server 2000 핫픽스 빌드를 빌드 사이에 780 및 807 year가 실행하는 서버 컴퓨터에 적용됩니다. SQL Server 인스턴스에 영향을 받는지 확인하려면 인스턴스를 BINN 폴더에 있는 Sqlmap70.dll 파일의 버전을 확인하십시오. 영향을 받는 파일 버전은 다음과 같은 특성이 있습니다:
   Date         Time   Version        Size           File name
   --------------------------------------------------------------
   28-Feb-2003  01:34  2000.80.778.0  176,696 bytes  Sqlmap70.dll
				

해결 방법

서비스 팩 정보

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

핫픽스 정보

참고 이 핫픽스 (빌드 811) SQL Server 2000 서비스 팩 3 적용할 수 있습니다.

이 수정의 영어 버전은 파일 특성을 가집니다 (또는 이상) 다음 표에. 이러한 파일의 시간과 날짜는 UTC (협정 세계시) 로 나열됩니다. 파일 정보에서는 현지 시간으로 변환됩니다. UTC와 로컬 시간의 차이를 알려면 제어판의 날짜 및 시간 도구에서 표준 시간대 탭을 사용하십시오.
   Date         Time   Version         Size             File name
   -------------------------------------------------------------------------------
   26-Feb-2003  03:41  2000.80.777.0      29,244 bytes  Dbmslpcn.dll     
   08-Feb-2003  05:43                    786,432 bytes  Distmdl.ldf
   08-Feb-2003  05:43                  2,359,296 bytes  Distmdl.mdf
   30-Jan-2003  01:55                        180 bytes  Drop_repl_hotfix.sql
   07-Apr-2003  19:15  2000.80.801.0   1,557,052 bytes  Dtsui.dll        
   24-Apr-2003  02:51                    747,927 bytes  Instdist.sql
   30-Jan-2003  01:55                      1,402 bytes  Inst_repl_hotfix.sql
   08-Feb-2003  06:40  2000.80.765.0      90,692 bytes  Msgprox.dll      
   01-Apr-2003  02:07                      1,873 bytes  Odsole.sql
   05-Apr-2003  01:46  2000.80.800.0      62,024 bytes  Odsole70.dll     
   02-Apr-2003  21:48  2000.80.796.0      57,904 bytes  Osql.exe         
   02-Apr-2003  23:15  2000.80.797.0     279,104 bytes  Pfutil80.dll     
   04-Apr-2003  21:27                  1,083,467 bytes  Replmerg.sql
   04-Apr-2003  21:53  2000.80.798.0     221,768 bytes  Replprov.dll     
   08-Feb-2003  06:40  2000.80.765.0     307,784 bytes  Replrec.dll      
   01-Apr-2003  02:23                  1,084,828 bytes  Replsys.sql
   16-Apr-2003  22:39                    115,892 bytes  Sp3_serv_uni.sql
   07-Apr-2003  17:44                     25,172 bytes  Sqldumper.exe    
   19-Mar-2003  18:20  2000.80.789.0      28,672 bytes  Sqlevn70.rll
   24-Apr-2003  05:39  2000.80.811.0     176,696 bytes  Sqlmap70.dll     
   08-Feb-2003  06:40  2000.80.765.0      57,920 bytes  Sqlrepss.dll     
   24-Apr-2003  05:39  2000.80.811.0   7,540,817 bytes  Sqlservr.exe     
   08-Feb-2003  06:40  2000.80.765.0      45,644 bytes  Sqlvdi.dll       
   26-Feb-2003  03:41  2000.80.777.0      29,244 bytes  Ssmslpcn.dll     
   26-Feb-2003  03:41  2000.80.777.0      82,492 bytes  Ssnetlib.dll     
   28-Feb-2003  01:34  2000.80.778.0      98,872 bytes  Xpweb70.dll
참고 파일 종속성, 최신 핫픽스 또는 파일이 포함된 기능을 인해 추가 파일이 포함될 수도 있습니다.

현재 상태

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

해결 과정

문제를 해결하려면 반환될 행이 하나만 있는 COMPUTE 수행하는 것이 쿼리를 수정할 수 있습니다. 예를 들어, 다음과 같은 문제가 발생하지 않도록 "현상" 절에 있는 쿼리를 수정할 수 있습니다:
EXEC master..xp_sendmail 
 @recipients = 'recipient_email_address',
 @message = 'Total Sum of Job ID' ,
 @subject = 'Compute Sum',
 @width = 133 ,
 @query = 'IF EXISTS (SELECT 1  FROM pubs.dbo.employee WHERE 1=0)  SELECT emp_id, fname, minit, lname, job_id, job_lvl, pub_id FROM pubs.dbo.employee WHERE 1=0 COMPUTE SUM (job_id) ELSE SELECT ''No Data'' as [SUM]'

속성

기술 자료: 819955 - 마지막 검토: 2014년 2월 24일 월요일 - 수정: 9.4
본 문서의 정보는 다음의 제품에 적용됩니다.
  • Microsoft SQL Server 2000 Developer Edition
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 2000 Enterprise Edition
  • Microsoft SQL Server 2000 Personal Edition
  • Microsoft SQL Server 2000 Workgroup Edition
  • Microsoft SQL Server 2000 Desktop Engine (Windows)
  • Microsoft SQL Server 2000 Enterprise Edition 64-bit
키워드:?
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbqfe kbsqlserv2000presp4fix kbfix kbbug KB819955 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