SQL WHERE 句でエイリアスを使用できないのはなぜですか?
Jan 05, 2025 am 11:43 AMWHERE 句でエイリアスを参照できません
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 サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

共通の脆弱性(SQLインジェクション、ブルートフォース攻撃)に対してMySQLを保護するにはどうすればよいですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
