Update: Ein Insert-Operation für eine temporäre Tabelle, die eine foreign Key-Einschränkung verfügt schlägt fehl, wenn der Ausführungsplan für die INSERT-Anweisung eine Join-Zusammenführung in SQL Server 2005 enthält

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 977100 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Microsoft stellt Updates für Microsoft SQL Server 2005 als downloadbare Datei. Da die Updates kumulativ sind, enthält jede neue Version alle Hotfixes und alle Sicherheitsupdates, die in vorherigen SQL Server 2005 enthalten waren.
Alles erweitern | Alles schließen

Problembeschreibung

Stellen Sie sich das folgende Szenario vor:
  • In Microsoft SQL Server 2005 müssen Sie eine Tabelle, die eine foreign Key-Einschränkung aufweist.
  • Ausführen eine INSERT-Anweisung viele Zeilen in dieser Tabelle einfügen.
  • Der Ausführungsplan für die INSERT-Anweisung enthält eine Verknüpfung Zusammenführungsoperation.
In diesem Szenario kann der Einfügevorgang fehl. Außerdem erhalten Sie folgende Fehlermeldung:
Fehler: 547, Schweregrad: 16, Status: 0
Die INSERT-Anweisung in Konflikt mit der FOREIGN KEY-Einschränkung "< foreign Key >".
Der Konflikt ist aufgetreten in Datenbank "< datenbankname >", "< tabellenname der >" Tabelle, Spalte '< spaltenname >'

Ursache

Der Beitrittsvorgang Seriendruck erwartet, die Zeilen zu empfangen, die gemäß den Verknüpfungsspalten sortiert sind. Allerdings erhält die Join-Zusammenführung in der Situation, die im Abschnitt "Problembeschreibung" erwähnt wird, nicht die eingefügten Zeilen in der richtigen Reihenfolge. Dieses Problem tritt auf, weil der Ausführungsplan neue Zeilen aus einem Index liest die Verknüpfungsspalten, deren Schlüssel entsprechen. SQL Server liest jedoch den Index in Reservierung Reihenfolge statt im Schlüssel Reihenfolge.

Lösung

Die Fehlerbehebung für dieses Problem wurde zuerst im kumulative Update 7 für SQL Server 2005 Service Pack 3 veröffentlicht. Weitere Informationen zu diesem kumulativen Update-Paket klicken Sie auf die folgende KB-Artikelnummer:
976951Kumulatives Updatepaket 7 für SQL Server 2005 Service Pack 3
Hinweis: Da die Builds kumulativ sind, enthält jede neue Update-Version aller Hotfixes, und alle Sicherheitsupdates, die in vorherigen SQL Server 2005 enthalten waren. Microsoft empfiehlt, dass Sie sich die neueste Version der Updates, die diesen Hotfix enthält anzuwenden. Weitere Informationen finden Sie die folgende KB-Artikelnummer:
960598SQL Server 2005 erstellt, die nach der Freigabe von SQL Server 2005 Service Pack 3 veröffentlicht wurden
Microsoft SQL Server 2005-Hotfixes sind für bestimmte SQL Server Servicepacks erstellt. Sie müssen einen SQL Server 2005 Service Pack 3 Hotfix auf eine Installation von SQL Server 2005 Service Pack 3 anwenden. Standardmäßig ist jeder Hotfix, der in einem SQL Server Servicepack zur Verfügung gestellt wird in das nächste Servicepack für SQL Server enthalten.

Abhilfe

Um dieses Problem zu umgehen, verwenden Sie eine der folgenden Methoden.

Methode 1

Wenden Sie eine LOOP-JOIN-Abfragehinweis der Beitrittsvorgang Zusammenführen zu deaktivieren.

Methode 2

Fügen Sie eine explizite ORDER BY-Klausel So sortieren Sie Zeilen in die Schlüsselspalten des Indexes, die Sie scannen.

Status

Microsoft hat bestätigt, dass dies ein Problem bei den Microsoft-Produkten handelt, die im Abschnitt "Gilt für" aufgeführt sind.

Weitere Informationen

Nachdem Sie den Hotfix angewendet haben, wird der Index in der Reihenfolge der Schlüssel gelesen werden.

Informationsquellen

Weitere Informationen zum inkrementellen Dienstmodell für SQL Server klicken Sie auf die folgende KB-Artikelnummer:
935897Ein inkrementelles Dienstmodell ist vom SQL Server-Team zum Übermitteln von Hotfixes für gemeldete Probleme verfügbar
Weitere Informationen dazu, wie Sie SQL Server 2005 Service Pack 3 zu erhalten klicken Sie auf die folgende KB-Artikelnummer:
913089So erhalten Sie das neueste Servicepack für SQL Server 2005
Weitere Informationen zu neuen Features und Verbesserungen in SQL Server 2005 Service Pack 3 finden Sie auf folgender Website von Microsoft:
http://go.microsoft.com/fwlink/?LinkId=131442
Weitere Informationen zum Benennungsschema für SQL Server-Updates finden Sie die folgende KB-Artikelnummer:
822499Neues Benennungsschema für Softwareupdate-Pakete von Microsoft SQL Server
Weitere Informationen zur Terminologie für Softwareupdates finden Sie die folgende KB-Artikelnummer:
824684Erläuterung von Standardbegriffen bei Microsoft Softwareupdates

Eigenschaften

Artikel-ID: 977100 - Geändert am: Donnerstag, 24. Dezember 2009 - Version: 2.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
Keywords: 
kbmt kbexpertiseadvanced kbsurveynew kbqfe kbfix KB977100 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: 977100
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