首页 >数据库 >mysql教程 >为什么不能在 PostgreSQL 查询的 WHERE 子句中使用别名?

为什么不能在 PostgreSQL 查询的 WHERE 子句中使用别名?

Linda Hamilton
Linda Hamilton原创
2024-12-27 12:45:11899浏览

Why Can't I Use Aliases in the WHERE Clause of a PostgreSQL Query?

在 WHERE 子句中引用别名:探索

在 PostgreSQL (psql) 中,无法直接在 WHERE 子句中引用别名,因为到执行命令。在应用别名之前执行 WHERE 子句,导致错误“列“_year”不存在”。

出现这种情况是因为 WHERE 子句操作的是原始列名,而别名是稍后才应用的,在结果集生成期间。因此,执行 WHERE 子句时无法识别别名。

要解决此问题,必须重写查询以直接在 WHERE 子句中使用原始列名。例如,考虑以下查询:

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

此查询将失败,并显示错误“列“_year”不存在”。要修复此问题,必须将 WHERE 子句中的别名替换为原始列名:

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

以上是为什么不能在 PostgreSQL 查询的 WHERE 子句中使用别名?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn