1. ホーム
  2. マイスル

[解決済み】MySQLクエリのWHERE句でカラムエイリアスを使用するとエラーが発生する。

2022-04-04 17:46:59

質問

以下のようなクエリを実行しているのですが、このようなエラーが発生します。

#1054 - 'IN/ALL/ANY サブクエリ'内の不明な列 'guaranteed_postcode'

SELECT `users`.`first_name`, `users`.`last_name`, `users`.`email`,
SUBSTRING(`locations`.`raw`,-6,4) AS `guaranteed_postcode`
FROM `users` LEFT OUTER JOIN `locations`
ON `users`.`id` = `locations`.`user_id`
WHERE `guaranteed_postcode` NOT IN #this is where the fake col is being used
(
 SELECT `postcode` FROM `postcodes` WHERE `region` IN
 (
  'australia'
 )
)

私の質問は、なぜ同じDBクエリのWhere句で偽のカラムを使用することができないのでしょうか?

どうすればいいですか?

GROUP BY、ORDER BY、またはHAVING句では、カラム・エイリアスのみを使用することができます。

標準SQLでは 列のエイリアスを参照するのは、WHERE 節があります。この制限は なぜなら、WHERE コードが を実行した場合、カラムの値はまだ が決定される。

コピー元 MySQL ドキュメント

コメントで指摘されているように、代わりにHAVINGを使用するとうまくいくかもしれません。この質問にも目を通しておいてください。 WHEREとHAVINGの比較 .