Update: FOR XML EXPLICIT: Konflikt-Attribut in Xmltext wird nicht überschrieben, wenn Xmltext enthält DBCS

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

Problembeschreibung

Ein XML EXPLICIT-Modus unter bestimmten Bedingungen mit der Xmltext-Element als Double-Byte-Zeichensatz (DBCS) definiert, eine Abfrage das Konflikt-Attribut kann nicht überschrieben und erzeugt möglicherweise XML, die nicht wohlgeformt ist.

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

In ein XML EXPLICIT-Modus unter normalen Bedingungen wenn ein Attribut, das in der Xmltext-Element verursacht einen Konflikt mit einem Attribut angezeigt wird, die auf derselben Elementebene abgerufen wird ist das Attribut im Xmltext ignoriert überschrieben und. Unter bestimmten Bedingungen mit DBCS Konflikt-Attribut wird nicht überschrieben, jedoch wird stattdessen dupliziert. Dies erzeugt XML, die nicht wohlgeformt ist.

Dieses Verhalten zu reproduzieren, erstellen Sie eine Tabelle, eine Zeile einfügen und Abfragen in der Tabelle wie folgt:
create table T1 (F0 int primary key, F1 TEXT collate Japanese_CI_AS)
go
insert into T1 values (111, '<elt1 att0="222" att1="?"><elt2 att2="?" /></elt1>')
go
select 1 as TAG, 0 as parent, F1 as [elt1!1!!xmltext], F0 as [elt1!1!att0] from T1 for xml explicit
				
werden zurückgegeben, die folgenden
-- [INCORRECT RESULT] - att0 is not overwritten.

XML_F52E2B61-18A1-11d1-B105-00805F49916B                                                                                                                                                                                                                         
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
<elt1 att0="111" att0="222" att1="?"><elt2 att2="?" /></elt1>

				
Wenn das erwartete Ergebnis sollte lauten wie folgt:
-- [EXPECTED  RESULT] - att0="222" is overwritten with att0="111"

XML_F52E2B61-18A1-11d1-B105-00805F49916B                                                                                                                                                                                                                         
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
 <elt1 att0="111" att1="?"><elt2 att2="?" /></elt1>
				

Eigenschaften

Artikel-ID: 290083 - 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 KB290083 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: 290083
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