gpt4 book ai didi

mysql - where 子句中的计算列 - 性能

转载 作者:行者123 更新时间:2023-11-29 20:11:56 25 4
gpt4 key购买 nike

因为您不能像这样在 MySQL 的 where 子句中使用计算列:

SELECT a,b,c,(a*b+c) AS d FROM table
WHERE d > n
ORDER by d

你必须使用

SELECT a,b,c,(a*b+c) AS d FROM table
WHERE (a*b+c) > n
ORDER by d

计算(在该示例中“(a*b+c)”每行执行一次还是两次?有没有办法让它更快?我觉得很奇怪,可以在列上进行排序,但不能WHERE 子句。

最佳答案

您可以使用 HAVING 来过滤计算列:

SELECT a,b,c,(a*b+c) AS d, n FROM table
HAVING d > n
ORDER by d

请注意,您需要在 SELECT 子句中包含 n 才能使其正常工作。

关于mysql - where 子句中的计算列 - 性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40035796/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com