Heim > Datenbank > MySQL-Tutorial > Warum kann ich in meiner SQL-WHERE-Klausel keine Aliase verwenden?

Warum kann ich in meiner SQL-WHERE-Klausel keine Aliase verwenden?

Barbara Streisand
Freigeben: 2025-01-05 11:43:44
Original
379 Leute haben es durchsucht

Why Can't I Use Aliases in My SQL WHERE Clause?

Aliase können in der WHERE-Klausel nicht referenziert werden

Beim Versuch, Aliase in der WHERE-Klausel einer SQL-Anweisung zu referenzieren, kann es zu einem Fehler kommen Zeigt an, dass die angegebene Spalte nicht vorhanden ist. Dieser Fehler tritt auf, weil die SQL-Ausführung einer bestimmten Reihenfolge folgt und die WHERE-Klausel vor der SELECT-Klausel ausgewertet wird. Folglich sind in der SELECT-Klausel definierte Aliase zum Zeitpunkt der Ausführung der WHERE-Klausel nicht erkennbar.

Ursache

Im bereitgestellten Beispiel versucht die folgende Abfrage, Zeilen zu filtern basierend auf einem Alias ​​(_year), der in der SELECT-Klausel erstellt wurde:

SELECT
    SUBSTRING(pk, 6, 2)::INT AS _year
FROM
    listing
WHERE
    _year > 90
Nach dem Login kopieren

Diese Abfrage führt zu Folgendem Fehler:

ERROR: column "_year" does not exist
Nach dem Login kopieren

Lösung

Um dieses Problem zu beheben und Aliase in der WHERE-Klausel zu referenzieren, muss die Abfrage neu geschrieben werden, um stattdessen die zugrunde liegende Spalte zu verwenden:

SELECT
    SUBSTRING(pk, 6, 2)::INT AS _year
FROM
    listing
WHERE
    SUBSTRING(pk, 6, 2)::INT > 90
Nach dem Login kopieren

Durch direkte Referenzierung der Spalte (pk), die zum Erstellen des Alias ​​(_year) verwendet wird, wird die Abfrage erfolgreich ausgeführt und ruft das Gewünschte ab Ergebnisse.

Das obige ist der detaillierte Inhalt vonWarum kann ich in meiner SQL-WHERE-Klausel keine Aliase verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage