SQL 查询中直接使用列别名进行计算的限制
在给定的 SQL 查询中,尝试在表达式 ROUND(avg_time * cnt, 2)
中使用列别名 avg_time
和 cnt
会导致错误“列“avg_time”不存在”。
根本原因在于 SELECT
语句的计算顺序。程序同时处理整个 SELECT
语句,因此在那个时间点无法识别别名值。
解决方案:使用嵌套子查询
为了解决这个问题,可以使用子查询来封装查询,从而有效地创建一个中间数据集。在这个子查询中,可以创建所需的列别名 avg_time
和 cnt
。
SELECT stddev_time, max_time, avg_time, min_time, cnt, ROUND(avg_time * cnt, 2) as slowdown
FROM (
SELECT
COALESCE(ROUND(stddev_samp(time), 2), 0) as stddev_time,
MAX(time) as max_time,
ROUND(AVG(time), 2) as avg_time,
MIN(time) as min_time,
COUNT(path) as cnt,
path
FROM
loadtime
GROUP BY
path
ORDER BY
avg_time DESC
LIMIT 10
) X;
现在,执行此查询时,会先计算子查询,生成包含所需列别名的数据集。然后,后续的 SELECT
语句就可以成功引用这些别名了。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3