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

Update: MERGE UNION wird nicht mit viele UNION-Klauseln verwendet.

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: 295037
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
# FEHLER: 351918 (SHILOH_BUGS)
Problembeschreibung
Abfragen, die mehr als 20 UNION ALL-Klausel Zweige verwenden werden mit einer Union HASH anstelle von effizienter MERGE UNION ausgeführt, die bewirkt, dass eine übermäßige Speichernutzung und möglicherweise der Fehler der Abfrage. Eine Folge dieser ist, dass eine verteilte partitionierte Sicht auf 24 Knoten ausgeführte Pläne für unterschiedliche und weniger effizient als eine Ansicht auf 20 Knoten.
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
Abhilfe
Mithilfe einer MERGE UNION-Abfragehinweis wird dieses Problem umgehen. Stellen Sie sicher, dass alle Optimierungshinweise gründlich getestet wurden, bevor Sie in Produktion aufgenommen wird.
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

Schritte zum Reproduzieren des Verhaltens

  1. Öffnen Sie ein Fenster im Query Analyzer.
  2. Wählen Sie im Abfrage die Option Ausführungsplan anzeigen .
  3. Führen Sie die folgende Abfrage:
    use Northwindgoselect top 1 * from(select orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union allselect orderid from orders union all select orderid from orders) xxorder by orderid					
  4. Klicken Sie auf die Registerkarte Ausführungsplan , und beobachten Sie die Ergebnisse.
  5. Kommentieren Sie die folgende Zeile der Abfrage:
    union all select orderid from orders					
  6. Führen Sie die bearbeitete Abfrage aus, und beobachten Sie die Änderung im Plan auf die Registerkarte Ausführungsplan .

Warnung: Dieser Artikel wurde automatisch übersetzt.

Eigenschaften

Artikelnummer: 295037 – Letzte Überarbeitung: 01/16/2015 22:17:14 – Revision: 3.2

Microsoft SQL Server 2000 Standard Edition

  • kbnosurvey kbarchive kbmt kbbug kbfix kbsqlserv2000sp1fix KB295037 KbMtde
Feedback