Update: Fehlermeldung, wenn Sie die Komprimierung auf einer Tabelle in SQL Server 2008 schätzen: "Unterabfrage hat mehr als einen Wert"

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 956031 - Produkte anzeigen, auf die sich dieser Artikel bezieht
# Fehler: 50003626 (SQL-Hotfix)
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 mit früheren SQL Server 2008 enthalten waren.
Alles erweitern | Alles schließen

Auf dieser Seite

Problembeschreibung

Wenn Sie die Sp_estimate_data_compression_savings gespeicherte Prozedur auf einer Tabelle, die ein nicht gruppierter Primärschlüssel und einen oder mehrere nicht gruppierte Indizes in Microsoft SQL Server 2008 verfügt verwenden, erhalten Sie folgende Fehlermeldung:
Msg 512, Ebene 16, Status 1, Prozedur Sp_estimate_data_compression_savings Zeile 251
Unterabfrage hat mehr als einen Wert zurückgegeben. Dies ist nicht zulässig, wenn die Unterabfrage folgt =,! =, <, < =, >, > = oder wenn die Unterabfrage als Ausdruck verwendet wird.
Obwohl Sie diese Fehlermeldung erhalten, wird das Ergebnis zurückgegeben. Die Komprimierung Schätzungen für einige nicht gruppierte Indizes sind jedoch falsch.

Dieses Problem tritt auf, ob ein gruppierter Index vorhanden ist oder nicht.

Lösung

Informationen zu Service Packs

Installieren Sie das neueste Servicepack für SQL Server 2008, um dieses Problem zu beheben. Weitere Informationen finden Sie im folgenden Artikel der Microsoft Knowledge Base:
968382Beziehen der neuesten Service Packs für SQL Server 2008

Kumulatives Update-Informationen

Die Fehlerbehebung für dieses Problem wurde zuerst im kumulativen Update 2 freigegeben. Weitere Informationen, wie Sie dieses kumulative Updatepaket für SQL Server 2008 erhalten finden Sie im folgenden Artikel der Microsoft Knowledge Base:
958186Kumulatives Updatepaket 2 für SQL Server 2008
Hinweis: Da die Builds kumulativ sind, enthält jede neue Update-Version alle Hotfixes und alle Sicherheitsupdates, die mit früheren SQL Server 2008 enthalten waren. Wir empfehlen Sie die neueste Hotfix-Version, die diesen Hotfix enthält. Weitere Informationen finden Sie im folgenden Artikel der Microsoft Knowledge Base:
956909SQL Server 2008 erstellt, die nach SQL Server 2008 veröffentlicht wurde veröffentlicht wurden

Abhilfe

Um dieses Problem zu umgehen, geben Sie @ Index_id Parameter beim Ausführen der Sp_estimate_data_compression_savings gespeicherte Prozedur. Sie müssen die gespeicherte Prozedur einmal für jeden Index ausführen, wenn für die Sie schätzen möchten.

Status

Microsoft hat bestätigt, dass dies ein Problem in Microsoft-Produkten handelt, die im Abschnitt "Gilt für" aufgeführt sind. Dieses Problem wurde erstmals im SQL Server 2008 Service Pack 1.

Weitere Informationen

Die Sp_estimate_data_compression_savings gespeicherte Prozedur wird verwendet, um die aktuelle Größe der Tabellen zurückzugeben. Die Sp_estimate_data_compression_savings gespeicherten Prozedur schätzt auch die Tabellengröße für den angeforderten Komprimierungsstatus.

Schritte zum Reproduzieren des Problems

  1. Starten Sie SQL Server Management Studio, und dann eine Verbindung zu einer Instanz von SQL Server 2008 herstellen.
  2. Erstellen Sie eine neue Abfrage, und führen Sie die folgenden Anweisungen.
    CREATE DATABASE TEST
    GO
    USE Test
    GO
    
    CREATE TABLE REPRO(i int primary key nonclustered, a int)
    GO
    
    CREATE NONCLUSTERED INDEX NONCLUSTERED_REPRO ON REPRO(a)
    GO
    
    EXEC SP_ESTIMATE_DATA_COMPRESSION_SAVINGS @schema_name = 'dbo', @object_name = 'repro', @index_id = NULL, @partition_number = NULL, @data_compression = 'PAGE'
    
Weitere Informationen, welche Dateien geändert werden, sowie über alle Voraussetzungen für das kumulative Updatepaket anwenden, das den Hotfix enthält, der in diesem Knowledge Base-Artikel beschrieben wird, finden Sie die folgende KB-Artikelnummer:
958186Kumulatives Updatepaket 2 für SQL Server 2008

Informationsquellen

Weitere Informationen zur Liste der Builds, die nach der Veröffentlichung von SQL Server 2008 finden Sie im folgenden Artikel der Microsoft Knowledge Base:
956909SQL Server 2008 erstellt, die nach SQL Server 2008 veröffentlicht wurde veröffentlicht wurden
Weitere Informationen zu inkrementellen Dienstmodell für SQL Server finden Sie im folgenden Artikel der Microsoft Knowledge Base:
935897Ein inkrementelles Dienstmodell steht SQL Server-Team zum Übermitteln von Hotfixes für gemeldete Probleme
Weitere Informationen zum Benennungsschema für SQL Server-Updates finden Sie im folgenden Artikel der Microsoft Knowledge Base:
822499Neues Namensschema für Microsoft SQL Server-Softwareupdate-Paketen
Weitere Informationen zur Terminologie für Softwareupdates finden Sie im folgenden Artikel der Microsoft Knowledge Base:
824684Erläuterung von Standardbegriffen bei Microsoft Softwareupdates

Eigenschaften

Artikel-ID: 956031 - Geändert am: Mittwoch, 8. April 2009 - Version: 3.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Standard
Keywords: 
kbmt sql2008relnotedatabaseengine sql2008relnote kbbug kbqfe kbfix kbexpertiseadvanced kbprb KB956031 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: 956031
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