首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQL:如何更改查询以获得以下结果?

SQL:如何更改查询以获得以下结果?
EN

Stack Overflow用户
提问于 2020-11-13 09:06:23
回答 1查看 22关注 0票数 0

对于每个客户-产品对,我需要计算该产品在每个州的平均销售额。

实际表("sales“表):

代码语言:javascript
运行
复制
cust  | prod  | state | quant
Bloom | Bread |  NY   | 1
Bloom | Butter|  NJ   | 2
.
.
.

我的问题是:

代码语言:javascript
运行
复制
SELECT cust, prod, state, AVG(quant)
from sales
group by cust, prod, state;

结果:

代码语言:javascript
运行
复制
cust  | prod  | state | avg(quant)
Bloom | Bread |  NY   | 1
Bloom | Butter|  NJ   | 2

我想要的结果是:

代码语言:javascript
运行
复制
cust  | prod  |  NY  | NJ
Bloom | Bread |  1   | 2
EN

回答 1

Stack Overflow用户

发布于 2020-11-13 09:21:39

这是一个支点。

代码语言:javascript
运行
复制
SELECT
    cust,
    prod,
    AVG(CASE WHEN state = 'NY' THEN quant END) AS 'NY',
    AVG(CASE WHEN state = 'NJ' THEN quant END) AS 'NJ'
FROM sales
GROUP BY cust, prod

如果您不能像那样对状态进行硬编码,请参阅MySQL pivot row into dynamic number of columns了解如何在存储过程中实现动态透视。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64814052

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档