Update: Wenn Sie eine Abfrage ausführen, die MIN oder MAX-Funktion für eine partitionierte Sicht in SQL Server 2008 verwendet, führt die Abfrage viel langsamer als beim Ausführen der gleichen Abfrage in SQL Server 2005

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 973255 - Produkte anzeigen, auf die sich dieser Artikel bezieht
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 Sicherheitsupdates, die in vorherigen SQL Server 2008 enthalten waren.
Alles erweitern | Alles schließen

Problembeschreibung

In Microsoft SQL Server 2008 erstellen Sie eine partitionierte Sicht. Ausführen eine Abfrage, die die Min- oder MAX Aggregatfunktion für die partitionierte Sicht verwendet. Allerdings finden Sie möglicherweise die in SQL Server 2008 als, wenn Sie dieselbe Abfrage in SQL Server 2005 ausgeführt wesentlich langsamer Abfrage ausgeführt wird.

Wenn Sie den Ausführungsplan der Abfrage untersuchen, finden Sie, dass der TOP-Operator im Ausführungsplan in SQL Server 2005 dargestellt. Der TOP-Operator stellt jedoch kein im Ausführungsplan in SQL Server 2008 dar.

Der Ausführungsplan in SQL Server 2005 ähnelt z. B. die folgenden:
  |--Stream Aggregate(DEFINE:([Expr1190]=MAX([partialagg1191])))
       |--Concatenation
            |--Top(TOP EXPRESSION:((1)))
            |    |--Clustered Index Scan(OBJECT:([Server].[dbo].[Database].[PK]), ORDERED BACKWARD)
            |--Top(TOP EXPRESSION:((1)))
                 |--Clustered Index Scan(OBJECT:([Server].[dbo].[Database].[PK]), ORDERED BACKWARD)
jedoch der Ausführungsplan der gleichen Abfrage in SQL Server 2008 die folgenden ähnelt:
  |--Stream Aggregate(DEFINE:([Expr1190]=MAX([partialagg1191])))
       |--Concatenation
            |--Stream Aggregate(DEFINE:([partialagg1191]=MAX([Server].[dbo].[Database].[Column])))
            |    |--Index Scan(OBJECT:([Server].[dbo].[Database].[Index]))
            |--Stream Aggregate(DEFINE:([partialagg1191]=MAX([Server].[dbo].[Database].[Column])))
                 |--Index Scan(OBJECT:([Server].[dbo].[Database].[Index]))

Ursache

Die SQL-Datenbank-Engine führt eine Regel, die die Funktionen MIN und MAX Aggregation TOP (1)-Operator und der Index Seek-Operator auf den Ausführungsplan verwenden übersetzt. In diesem Szenario funktioniert die Regel nicht in SQL Server 2008 jedoch. Aus diesem Grund wird ein falscher Index in der Partitionsansicht verwendet. Dadurch wird das Leistungsproblem.

Lösung

Die Fehlerbehebung für dieses Problem wurde zuerst im kumulative Update 4 für SQL Server 2008 Service Pack 1 veröffentlicht. Weitere Informationen zu diesem kumulativen Update-Paket klicken Sie auf die folgende KB-Artikelnummer:
973602Kumulatives Updatepaket 4 für SQL Server 2008 Service Pack 1
Hinweis: Da die Builds kumulativ sind, enthält jede neue Update-Version aller Hotfixes, und alle Sicherheitsupdates, die in vorherigen SQL Server 2008 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:
970365SQL Server 2008 erstellt, die nach der Freigabe von SQL Server 2008 Service Pack 1 veröffentlicht wurden
Microsoft SQL Server 2008 Hotfixes sind für bestimmte SQL Server Servicepacks erstellt. Sie müssen einen Hotfix für SQL Server 2008 Service Pack 1 auf eine Installation von SQL Server 2008 Service Pack 1 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.
Aktivieren Sie das Ablaufverfolgungsflag 4199 für diesen Hotfix wirksam wird.

Status

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

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 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: 973255 - Geändert am: Dienstag, 22. September 2009 - Version: 1.1
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Workgroup
Keywords: 
kbmt kbsurveynew kbfix kbqfe kbexpertiseadvanced KB973255 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: 973255
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