Update: Falsche Ergebnisse oder Einschränkungsverletzung, wenn Sie einer SELECT- oder DML-Anweisung ausführen verwendet die Row_number-Funktion und einen paralllen Ausführungsplan in SQL Server 2008

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

Problembeschreibung

Betrachten Sie das folgende Szenario:
  • Ausführen eine parallele Abfrage, verwendet die ROW_NUMBER die Funktion Microsoft SQL Server 2008.
  • Sie versuchen, führen Sie die Abfrage mit eine Unterabfrage, die innerhalb einer WÄHLEN SIE -Anweisung oder eine Anweisung (Data Manipulation Language, DML).
In diesem Szenario tritt möglicherweise eines der folgenden Probleme:
  • Wenn Sie innerhalb die Abfrage ausführen, erhalten Sie falsche Ergebnisse derWÄHLEN SIE viele Male-Anweisung.
  • Die Tabelle möglicherweise falsche Daten enthalten, wenn die Abfrage in einer DML-Anweisung ausgeführt wird. Wenn die Tabelle Einschränkungen hat, könnte die Anweisung mit einer Einschränkungsverletzung fehl.

    Zum Beispiel ein EINFÜGEN Anweisung schlägt möglicherweise fehl, und ein Primärschlüsselverletzung-Fehler tritt auf, wenn die Tabelle einen Primärschlüssel verfügt.


Hinweis Diese Probleme können in folgenden Situationen auftreten:
  • Legen Sie die MAXDOP Abfragehinweisoption auf einen Wert, der größer ist 2.
  • Legen Sie die Max Degree of Parallelism Option, um einen Wert größer als 2 in der Konfiguration des Servers.

Lösung

Um dieses Problem zu beheben, beziehen Sie das neueste Servicepack für SQL Server 2008. Weitere Informationen finden Sie in folgendem Artikel der Microsoft Knowledge Base anzuzeigen:

968382 So erhalten Sie das neueste Servicepack für SQL Server 2008

Abhilfe

Um dieses Problem zu umgehen, verwenden Sie eine der folgenden Methoden:
  • Aktivieren Sie 4134 Ablaufverfolgungs-Flag, wenn Sie eine der folgenden Updates angewendet haben:
    • Kumulative Updatepaket 6 SQL Server 2008 oder ein späteres Kumulatives Update-Paket für SQL Server 2008
    • Kumulative Updatepaket 2 für SQL Server 2008 Service Pack 1 (SP1) oder ein späteres Kumulatives Update-Paket für SQL Server 2008 SP1


    Weitere Informationen zum Aktivieren von Ablaufverfolgungsflags finden Sie auf die folgende MSDN-Website:
    Gewusst wie: Aktivieren des Ablaufverfolgungsflags
  • Im Abschnitt "Abhilfe" in der Microsoft Knowledge Base-Artikel 970198.

    Weitere Informationen finden Sie in folgendem Artikel der Microsoft Knowledge Base anzuzeigen:
    970198 Update: Wenn Sie eine Abfrage ausführen, die die Row_number-Funktion in SQL Server 2008 verwendet, erhalten ein falsches Ergebnis

Eigenschaften

Artikel-ID: 2589980 - Geändert am: Montag, 22. August 2011 - Version: 1.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Enterprise Evaluation
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 Express with Advanced Services
  • Microsoft SQL Server 2008 Service Pack 1
  • Microsoft SQL Server 2008 Service Pack 2
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Standard Edition for Small Business
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
Keywords: 
kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2589980 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: 2589980
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