Update: Falsche Ergebnisse mit an der Spalte in Binary konvertiert

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.

282243
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
# Fehler: 351225 (SHILOH_bugs)
# FEHLER: 100900 (SQLBUG_70)
Problembeschreibung
Wenn Sie eine Sortierung ohne Berücksichtigung der Groß-und Kleinschreibung verwenden, wenn eine korrelierte Unterabfrage oder Verknüpfung erfolgt auf eine zeichenbasierte Spalte, die in binary oder Varbinary konvertiert wurde und wenn der Optimierer einen Plan, der eine Tabelle Spool oder Hash-Übereinstimmung mit Cache verwendet wählt, möglicherweise falsche Ergebnisse zurückgegeben werden. Die Zeilen, die zurückgegeben werden, sind die Übereinstimmungen basierend auf einen Vergleich ohne Berücksichtigung der Groß-und Kleinschreibung der Spalte, anstatt einen binären Vergleich.
Ursache
Auf einem Server ohne Unterscheidung der Groß-und Kleinschreibung werden aus der Tabelle Spool oder Hash-Cache-Lookups ohne Berücksichtigung der Groß-und Kleinschreibung anstelle einer binären Suche durchgeführt. Da die Spalte in einen binären Typ umgewandelt wurde, sollten Sie eine binäre Suche durchgeführt werden.
Lösung

SQLServer 2000

Installieren Sie das neueste Service Pack für Microsoft 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

SQLServer 7.0

Installieren Sie das neueste Servicepack für Microsoft SQL Server 7.0, um dieses Problem zu beheben. Weitere Informationen finden Sie die folgende KB-Artikelnummer:
301511Info: Wie Sie das neueste SQL Server 7.0 Service Pack erhalten
Hinweis : der folgende Hotfix wurde erstellt, bevor Microsoft SQL Server 7.0 Service Pack 4.

Die englische Version dieses Updates müsste die folgenden Dateiattribute oder höher:
   Version      File name      Platform   ----------------------------------------------------   7.00.0919    s70919i.exe    x86        SP2-based fix   7.00.0919    s70919a.exe    Alpha      SP2-based fix   7.00.0970    s70970i.exe    x86        SP3-based fix   7.00.0970    s70970a.exe    Alpha      SP3-based fix				
Hinweis : aufgrund von Dateiabhängigkeiten das aktuellste Update oder Feature, das die obigen Dateien enthält, auch enthält eventuell zusätzliche Dateien.

Status
Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den in diesem Artikel genannten Microsoft-Produkten handelt.

SQLServer 2000
Dieses Problem wurde erstmals im SQL Server 2000 Service Pack 1.

SQLServer 7.0
Dieses Problem wurde erstmals im Microsoft SQL Server 7.0 Service Pack 4.
Weitere Informationen
Das folgende Skript zeigt, das Problem. Gibt bevor Sie das Update anwenden, das Skript zwei Zeilen mit einem TestCode 'a', anstatt eine Zeile mit Wert 'a' und eine Sekunde zurück mit Wert "A".
CREATE TABLE #tblIDs(TestID int, Code varchar(1))CREATE TABLE #tblValues(Code varchar(1))INSERT INTO #tblIDs(TestID, Code) VALUES(1,'a')INSERT INTO #tblIDs(TestID, Code) VALUES(2,'A')INSERT INTO #tblValues(Code) VALUES('a')INSERT INTO #tblValues(Code) VALUES('A')SELECT #tblValues.Code AS TestCode,    (SELECT #tblIDs.TestID FROM #tblIDs       WHERE CAST(#tblIDs.Code AS varbinary) =             CAST(#tblValues.Code AS varbinary)    ) AS TestID FROM #tblValuesDROP TABLE #tblIDsDROP TABLE #tblValuesGO				
Sortieren von Bestellung konvertieren Konvertierung

Warnung: Dieser Artikel wurde automatisch übersetzt

Eigenschaften

Artikelnummer: 282243 – Letzte Überarbeitung: 01/16/2015 21:19:14 – Revision: 3.1

  • Microsoft SQL Server 7.0 Standard Edition
  • Microsoft SQL Server 2000 Standard Edition
  • kbnosurvey kbarchive kbmt kbbug kbfix kbsqlserv2000sp1fix KB282243 KbMtde
Feedback