首页 >数据库 >mysql教程 >如何在 PostgreSQL 中按别名排序并避免'列不存在”错误?

如何在 PostgreSQL 中按别名排序并避免'列不存在”错误?

Patricia Arquette
Patricia Arquette原创
2024-12-22 18:09:15879浏览

How to Order By an Alias in PostgreSQL and Avoid the

如何在 PostgreSQL 中按别名排序:解决“列不存在”错误

在 PostgreSQL 中,使用别名时,您可以对结果排序时可能会遇到错误。例如,考虑以下查询:

SELECT 
    title, 
    (stock_one + stock_two) AS global_stock
FROM
    product
ORDER BY
    global_stock = 0,
    title;

在 PostgreSQL 8.1.23 中执行此查询可能会产生错误:查询失败:错误:列“global_stock”不存在。出现此错误的原因是别名“global_stock”未被识别为“产品”表中的现有列。

要解决此问题,您有几个选项:

选项1:按位置排序

PostgreSQL 允许按列的位置而不是其名称进行排序。例如,您可以编写:

select 
    title, 
    ( stock_one + stock_two ) as global_stock
from product
order by 2, 1

此查询首先按第二列(即“global_stock”)对结果进行排序,然后按第一列(即“title”)排序。

选项 2:包装在子查询中

另一种方法是将原始查询包装在子查询中并使用 CASE 语句来处理排序:

SELECT *
from
(
    select 
        title, 
        ( stock_one + stock_two ) as global_stock
    from product
) x
order by (case when global_stock = 0 then 1 else 0 end) desc, title

此查询首先创建一个计算“global_stock”值的子查询。然后,子查询被包装在另一个 SELECT 语句中,该语句使用 CASE 语句根据项目的可用性对结果进行排序(0 表示可用,1 表示不可用)。

以上是如何在 PostgreSQL 中按别名排序并避免'列不存在”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

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