如何在 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中文网其他相关文章!