首页 > 数据库 > mysql教程 > 如何在 SQL WHERE 子句中正确引用别名?

如何在 SQL WHERE 子句中正确引用别名?

Mary-Kate Olsen
发布: 2024-12-26 14:03:14
原创
828 人浏览过

How Can I Correctly Reference Aliases in a SQL WHERE Clause?

在 WHERE 子句中引用别名

使用 SQL 查询时,通常需要使用别名为表或表达式提供临时名称。这可以提高代码的可读性和可维护性。但是,重要的是要注意在查询的不同部分引用别名时的限制。

问题

在提供的示例中,进行了尝试在查询的 WHERE 子句中引用别名 (_year)。但是,这会导致错误:

ERROR:  column "_year" does not exist
登录后复制

出现此错误是因为 WHERE 子句先于 SELECT 子句执行。在执行时,数据库尚未遇到 SELECT 子句中的别名定义,因此无法识别它。

解决方案

要解决此问题,您可以重写查询,以便在 WHERE 子句本身中定义别名。这确保了执行 WHERE 子句时别名可用:

SELECT
    SUBSTRING(pk, 6, 2)::INT AS _year
FROM
    listing
WHERE
    SUBSTRING(pk, 6, 2)::INT > 90
登录后复制

通过将别名定义放在 WHERE 子句中,您可以在同一子句中引用别名,而不会遇到错误。

以上是如何在 SQL WHERE 子句中正确引用别名?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板