Sie sind zurzeit offline. Es wird auf die erneute Herstellung einer Internetverbindung gewartet.

Update: Verwenden von Xp_sendmail mit einer COMPUTE-Klausel führt eine Zugriffsverletzung

Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.

Den englischen Originalartikel können Sie über folgenden Link abrufen: 819955
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
# FEHLER: 469145 (SHILOH_BUGS)
Problembeschreibung
Ein Aufruf erweiterte gespeicherte Prozedur Xp_sendmail kann behandelte Zugriffsverletzung verursachen, wenn alle folgenden Bedingungen erfüllt sind:
  • Der Aufruf Xp_sendmail muss @ Query verwenden Parameter, um ein Recordset zu senden.
  • Die Abfrage an die @ Abfrage weitergegeben muss Parameter eine COMPUTE-Klausel enthalten.
  • Die Abfrage muss keine Zeilen zurückgeben.
Hier ist ein Beispiel einer Abfrage, die dieses Problem auftreten kann:
 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)'
Hinweis dieses Problem handelt eine Regression, die nur eine kleine Anzahl von Post-SQL Server 2000 Servicepack 3 Hotfix-Versionen auswirkt. Dieses Problem betrifft nur Server-Computern, auf denen SQL Server 2000 Hotfix-Builds zwischen Build 780 und 807 (inklusive) ausgeführt wird. Überprüfen Sie die Version der Sqlmap70.dll-Datei, die ist im Ordner "BINN" auf der die Instanz von SQL Server, um festzustellen, ob die Instanz betroffen ist. Die Version der betroffenen Datei hat die folgenden Attribute:
   Date         Time   Version        Size           File name   --------------------------------------------------------------   28-Feb-2003  01:34  2000.80.778.0  176,696 bytes  Sqlmap70.dll				
Lösung

Informationen zu Service Packs

Installieren Sie das neueste Service Pack für Microsoft SQL Server 2000, um dieses Problem zu beheben. Weitere Informationen finden Sie die folgende KB-Artikelnummer:
290211So erhalten Sie das neueste Service Pack für SQL Server 2000

Hotfix-Informationen

Hinweis: Dieser Hotfix (Build 811) kann nur auf SQL Server 2000 Service Pack 3 angewendet werden.

Die englische Version dieses Updates weist die in der nachstehenden Tabelle aufgelisteten Dateiattribute (oder höher) auf. Die Datums- und Uhrzeitangaben für diese Dateien werden in Coordinated Universal Time () angegeben. Wenn Sie sich die Dateiinformationen ansehen, werden diese Angaben in die lokale Zeit konvertiert. Um die Differenz zwischen UTC und der Ortszeit zu ermitteln verwenden Sie die Registerkarte Zeitzone des Tools „ Datum und Uhrzeit in der Systemsteuerung.
   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
Hinweis aufgrund der Dateiabhängigkeiten, neueste Hotfix oder Feature, das die Dateien enthält, möglicherweise auch weitere Dateien enthalten.
Status
Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den in diesem Artikel genannten Microsoft-Produkten handelt. Dieses Problem wurde erstmals im Microsoft SQL Server 2000 Service Pack 4.
Abhilfe
Um das Problem zu umgehen können Sie die Abfrage ändern, sodass es nur eine COMPUTE durchführt, wenn Zeilen zurückgegeben werden soll. Beispielsweise können Sie ändern die Abfrage im Abschnitt "Problembeschreibung" wie folgt, um das Problem zu vermeiden:
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]'
Informationsquellen

Warnung: Dieser Artikel wurde automatisch übersetzt.

Eigenschaften

Artikelnummer: 819955 – Letzte Überarbeitung: 02/26/2014 23:32:04 – Revision: 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 KbMtde
Feedback