Update: Xp_enumgroups erzeugt eine Zugriffsverletzung, wenn eine große Parameter übergeben

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 294338 - Produkte anzeigen, auf die sich dieser Artikel bezieht
# FEHLER: 351927 (SHILOH_BUGS)
Alles erweitern | Alles schließen

Problembeschreibung

Xp_enumgroups enthält eine Liste der lokalen Microsoft Windows NT-Gruppen oder eine Liste von globalen Gruppen in einer angegebenen Windows NT-Domäne definiert den Parameter bereitgestellten.

Wenn ein großer Parameter an die Xp_enumgroups gespeicherte Prozedur übergeben wird, eine Zugriffsverletzung generiert und die Verbindung beendet, mit der Fehlermeldungen, die folgen:
ODBC: Fehlermeldung 0, Schweregrad 19, Status 1
SqlDumpExceptionHandler: Prozess 53 generiert der schwere Ausnahmefehler c0000005 EXCEPTION_ACCESS_VIOLATION. SQL Server beendet diesen Prozess.

ODBC: Fehlermeldung 0, Schweregrad 20, Status 1
Gespeicherte Funktion 'Xp_enumgroups' in der Bibliothek "xplog70.dll" generiert eine Zugriffsverletzung. SQL Server ist 53 Prozess beendet.

Unterbrochene Verbindung
Der SQL-Serverdienst beendet die Zugriffsverletzung, wenn die Größe des als Parameter übergebene Zeichenfolge viel größer ist. Fehlermeldung, das auftritt, sieht etwa so:
[Microsoft][ODBC SQL Server-Treiber][DBMSLPCN]ConnectionCheckForData (CheckforData()).
Server: Msg 11, Ebene 16, Status 1, Zeile 0
Allgemeiner Netzwerkfehler. Weitere Informationen finden Sie in der Dokumentation.

Lösung

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

Status

Microsoft hat bestätigt, dass dies ein Problem in SQL Server 2000 ist. Dieses Problem wurde erstmals im SQL Server 2000 Service Pack 1.

Weitere Informationen

Dieses Problem tritt nur auf, wenn größer ist als 228 Bytes die Größe der Zeichenfolge, die vom Xp_enumgroups aufgerufen wird. Der genaue Wortlaut der Fehlermeldung kann die Größe der übergebenen Zeichenfolge abhängig.

Beispielsweise wenn die Zeichenfolge 229 Bytes ist, zeigt dieses Fehlermeldung:
Server: Msg 3624 auf 20, Status 1, Prozedur Xp_enumgroups, 1

Speicherort: dbccdll.cpp:516
Ausdruck: pElem == Nachschlagen (-> m_DLLName.m_str pElem)
SPID: 51
Prozess-ID: 768

Unterbrochene Verbindung
Schritte zum Reproduzieren des Verhaltens

Die folgenden können Sie um das Problem zu reproduzieren.

  • Damit eine Zugriffsverletzung auftreten, verwenden Sie diesen Code:
    xp_enumgroups 'Scanning directory [C:\*]
    Scanning directory [C:\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\*]
    Scanning directory [C:\cmdcons\*]
    Scanning directory [C:\*]'
    						
  • Damit eine Zugriffsverletzung auftreten, und auch der SQL Server-Dienst verwenden beendet diesen Code verursachen:
    xp_enumgroups 'Scanning directory [C:\*]
    Scanning directory [C:\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\*]
    Scanning directory [C:\cmdcons\*]
    Scanning directory [C:\*]
    Scanning directory [C:\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\APSETUP\*]
    Scanning directory [C:\*]
    Scanning directory [C:\cmdcons\*]
    Scanning directory [C:\*]'
    						

Eigenschaften

Artikel-ID: 294338 - Geändert am: Donnerstag, 6. November 2003 - Version: 3.2
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2000 Standard Edition
Keywords: 
kbmt kbbug kbfix kbsqlserv2000sp1fix KB294338 KbMtde
Maschinell übersetzter Artikel
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: 294338
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

Ihr Feedback an uns

 

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