如何使此SQL查询更有效?
SELECT
(SELECT COUNT(*) FROM table WHERE price < 10) AS priceUnder10,
(SELECT COUNT(*) FROM table WHERE price BETWEEN 10 AND 20) AS price10to20,
(SELECT COUNT(*) FROM table WHERE price > 20) AS priceOver20,
(SELECT COUNT(*) FROM table WHERE colour = 'Red') AS colourRed,
(SELECT COUNT(*) FROM table WHERE colour = 'Green') AS colourGreen,
(SELECT COUNT(*) FROM table WHERE colour = 'Blue') AS colourBlue;
我已经在价格和颜色列上有索引,所以我正在寻找一种更好的方法来聚合数据.
我已经研究过使用GROUP BY,HAVING,自联接和窗口函数,但是无法弄清楚如何实现相同的结果.
任何建议非常感谢.
解决方法:
SELECT
COUNT(CASE WHEN price < 10 THEN 1 END) AS priceUnder10,
COUNT(CASE WHEN price BETWEEN 10 AND 20 THEN 1 END) AS price10to20,
COUNT(CASE WHEN price> 20 THEN 1 END) AS priceOver20,
COUNT(CASE WHEN colour = 'Red' THEN 1 END) AS colourRed,
COUNT(CASE WHEN colour = 'Green' THEN 1 END) AS colourGreen,
COUNT(CASE WHEN colour = 'Blue' THEN 1 END) AS colourBlue
from YourTable
WHERE price IS NOT NULL OR colour IN ('Red','Green','Blue' )
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。