ホームページ >データベース >mysql チュートリアル >SQL WHERE 句でエイリアスを使用できないのはなぜですか?

SQL WHERE 句でエイリアスを使用できないのはなぜですか?

Barbara Streisand
Barbara Streisandオリジナル
2025-01-05 11:43:44434ブラウズ

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

WHERE 句でエイリアスを参照できません

SQL ステートメントの WHERE 句でエイリアスを参照しようとすると、エラーが発生する場合があります指定された列が存在しないことを示します。このエラーは、SQL の実行が特定の順序に従っており、WHERE 句が SELECT 句より前に評価されるために発生します。その結果、SELECT 句で定義されたエイリアスは、WHERE 句の実行時に認識されません。

原因

この例では、次のクエリは行をフィルタリングしようとしています。 SELECT 句で作成されたエイリアス (_year) に基づく:

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

このクエリ次のエラーが発生します:

ERROR: column "_year" does not exist

解決策

この問題を解決し、WHERE 句でエイリアスを参照するには、基になるクエリを使用するようにクエリを書き直す必要があります。代わりに列:

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

エイリアスの作成に使用された列 (pk) を直接参照することによって(_year)、クエリは正常に実行され、目的の結果が取得されます。

以上がSQL WHERE 句でエイリアスを使用できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。