MSSQLSERVER_207
Gilt für: SQL Server
Details
attribute | Wert |
---|---|
Produktname | SQL Server |
Ereignis-ID | 207 |
Ereignisquelle | MSSQLSERVER |
Komponente | SQLEngine |
Symbolischer Name | SQ_BADCOL |
Meldungstext | Ungültiger Spaltenname '%.*ls'. |
Erklärung
Dieser Abfragefehler kann durch eines der folgenden Probleme verursacht werden.
Der Spaltenname ist falsch geschrieben, oder die Spalte ist in keiner der angegebenen Tabellen vorhanden.
Bei der Sortierung der Datenbank wird nach Groß-/Kleinschreibung unterschieden, und die in der Abfrage angegebene Schreibweise entspricht nicht der Schreibweise, die in der Tabelle für die Spalte definiert ist. Wenn eine Spalte z.B. als LastName angegeben ist und die Datenbank eine Sortierung verwendet, die nach Groß-/Kleinschreibung unterscheidet, geben Abfragen, die auf die Spalte als Lastname oder lastname verweisen, den Fehler 207 zurück, da der Spaltenname nicht übereinstimmt.
Auf einen in der SELECT-Klausel definierten Spaltenalias wird in einer anderen Klausel, beispielsweise WHERE oder GROUP BY, verwiesen. Beispielsweise wird in der folgenden Abfrage der Spaltenalias
Year
in der SELECT-Klausel definiert, und in der GROUP BY-Klausel wird auf diesen verwiesen.USE AdventureWorks2022; GO SELECT DATEPART(yyyy,OrderDate) AS Year, SUM(TotalDue) AS Total FROM Sales.SalesOrderHeader GROUP BY Year;
Aufgrund der Reihenfolge, in der die Abfrageklauseln verarbeitet werden, wird in diesem Beispiel der Fehler 207 zurückgegeben. Die Verarbeitungsreihenfolge ist die Folgende:
FROM
EIN
JOIN
WHERE
GROUP BY
WITH CUBE oder WITH ROLLUP
HAVING
SELECT
DISTINCT
ORDER BY
TOP
Da vor dem Verarbeiten der SELECT-Klausel kein Spaltenalias definiert wird, ist der Aliasname beim Verarbeiten der GROUP BY-Klausel unbekannt.
Die MERGE-Anweisung löst diesen Fehler aus, wenn die <merge_matched> Klausel spalten in der Quelltabelle referenziert, aber keine Zeilen von der Quelltabelle in der WHEN NOT MATCHED BY SOURCE-Klausel zurückgegeben werden. Dieser Fehler tritt auf, da auf die Spalten in der Quelltabelle nicht zugegriffen werden kann, wenn in der Abfrage keine Zeilen zurückgegeben werden. Die Klausel
WHEN NOT MATCHED BY SOURCE THEN UPDATE SET TargetTable.Col1 = SourceTable.Col1
kann beispielsweise dazu führen, dass die Anweisung fehlschlägt, wenn der Zugriff aufCol1
in der Quelltabelle nicht möglich ist.
Benutzeraktion
Überprüfen Sie die folgenden Informationen, und korrigieren Sie die Anweisung entsprechend.
Der Spaltenname ist in der Tabelle vorhanden und korrekt geschrieben. Im folgenden Beispiel wird die sys.columns-Katalogsicht abgefragt, um alle Spaltennamen der angegebenen Tabelle zurückzugeben.
SELECT name FROM sys.columns WHERE object_id = OBJECT_ID('schema_name.table_name');
Die Unterscheidung nach Groß-/Kleinschreibung der Datenbanksortierung. Mit der folgenden Anweisung wird die Sortierung der angegebenen Datenbank zurückgegeben.
SELECT collation_name FROM sys.databases WHERE name = 'database_name';
Die Abkürzung CS im Sortierungsnamen gibt an, dass bei der Sortierung nach Groß-/Kleinschreibung unterschieden wird. Beispiel: Latin1_General_CS_AS ist eine Sortierung, bei der nach Groß-/Kleinschreibung und nach Akzent unterschieden wird. Ändern Sie den Spaltennamen zu der in der Tabelle definierten Schreibweise des Spaltennamens.
Ein Verweis auf einen Spaltenalias ist ungültig. Ändern Sie die Anweisung, indem Sie den Ausdruck wiederholen, mit dem der Alias in der entsprechenden Klausel definiert wird, oder indem Sie eine abgeleitete Tabelle verwenden. Im folgenden Beispiel werden die Ausdrücke wiederholt, mit denen in der GROUP BY-Klausel der Alias
Year
definiert wird.USE AdventureWorks2022; GO SELECT DATEPART(yyyy,OrderDate) AS Year ,SUM(TotalDue) AS Total FROM Sales.SalesOrderHeader GROUP BY DATEPART(yyyy,OrderDate);
Im folgenden Beispiel wird eine abgeleitete Tabelle verwendet, um den Aliasnamen für andere Klauseln in der Abfrage verfügbar zu machen. Beachten Sie, dass der Alias
Year
in der FROM-Klausel definiert wird, die zuerst verarbeitet wird. Dadurch ist der Alias für die Verwendung in anderen Klauseln der Abfrage verfügbar.USE AdventureWorks2022; GO SELECT d.Year, SUM(TotalDue) AS Total FROM (SELECT DATEPART(yyyy,OrderDate) AS Year, TotalDue FROM Sales.SalesOrderHeader)AS d GROUP BY Year;
Die WHEN NOT MATCHED BY SOURCE-Klausel in der MERGE-Anweisung verweist auf einen Wert, auf den zugegriffen werden kann. Ändern Sie die MERGE-Anweisung so, dass die Quelltabelle in der WHEN NOT MATCHED BY SOURCE-Klausel mindestens eine Zeile zurückgibt. Möglicherweise müssen Sie z. B. die für die Klausel angegebene Suchbedingung hinzufügen oder überarbeiten. Wahlweise können Sie die Klausel so ändern, dass diese einen Wert angibt, der nicht auf die Quelltabelle verweist. Beispielsweise
WHEN NOT MATCHED BY SOURCE THEN UPDATE SET TargetTable.Col1 = <expression, or other available value>
.
Weitere Informationen
MERGE (Transact-SQL)
FROM (Transact-SQL)
SELECT (Transact-SQL)
UPDATE (Transact-SQL)