在 MySQL 查询的 WHERE 子句中使用列别名会产生错误

发布于 2022-07-28 23:16:13

我正在运行的查询如下,但是我收到了这个错误:

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'
 )
)

我的问题是:为什么我不能在同一个数据库查询的 where 子句中使用假列?

关注者
0
被浏览
19
1 个回答
  • 面试哥
    面试哥 2022-07-28
    为面试而生,有面试问题,就找面试哥。

    您只能在 GROUP BY、ORDER BY 或 HAVING 子句中使用列别名。

    标准 SQL 不允许您在 WHERE 子句中引用列别名。施加此限制是因为在执行 WHERE 代码时,可能尚未确定列值。

    复制自MySQL 文档

    正如评论中所指出的,使用 HAVING 代替可能会完成这项工作。确保也阅读这个问题:WHERE vsHAVING。



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看