首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在SQL Server中根据条件将行转置为列?

如何在SQL Server中根据条件将行转置为列?
EN

Stack Overflow用户
提问于 2019-10-29 09:59:42
回答 1查看 317关注 0票数 0

我有一个表,其中包含这四列-土壤类型、总小时数、体积和月份-年。

我已经提出了两个查询,以基于月-年条件根据土壤类型生成总小时数和总交易量。

下面是我的输出:

按土壤类型划分的总小时数:

代码语言:javascript
复制
SELECT 
    [Soil Type], [Month/Year],
    SUM([Total Hour]) AS 'Total_Hour' 
FROM 
    OVERALL_SUMMARY_ORIGINAL 
WHERE 
    [Month/Year] = '2019-10-01' 
GROUP BY 
    [Soil Type], [Month/Year] 
ORDER BY 
    [Soil Type]

输出:

土壤类型的总蓄积量:

代码语言:javascript
复制
SELECT 
    [Soil Type], [Month/Year],
    SUM([Volume]) AS 'Total Volume' 
FROM 
    OVERALL_SUMMARY_ORIGINAL 
WHERE 
    [Month/Year] = '2019-10-01' 
GROUP BY 
    [Soil Type], [Month/Year] 
ORDER BY 
    [Soil Type]

输出:

我一直在尝试弄清楚如何组合这些查询,以便SQL语句首先检查该土壤类型的总体积是否> 10000,如果满足条件,它将用该土壤类型的总体积除以总小时数。然后,SQL应将土壤类型列转置为行,如下所示:

我尝试使用SQL PIVOT函数,但无法生成所需的上述输出。有人能帮上忙吗?谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-29 14:35:31

如果我正确理解了您的问题,请尝试以下操作:

代码语言:javascript
复制
declare @product table(
 [Soil Type] varchar(50),
 [Month/Year] smalldatetime,
 [Total Hour] int,
 [Volume] int
)

insert into @product values ('Clay', '20190101', 2, 20)
insert into @product values ('Clay', '20190101', 3, 10)
insert into @product values ('Sandy', '20190101', 4, 10)
insert into @product values ('Sandy', '20190201', 2, 25)
insert into @product values ('Clay', '20190301', 8, 40)
insert into @product values ('Mixed', '20190101', 2, 25)
insert into @product values ('Mixed', '20190102', 1, 20)
insert into @product values ('Sand', '20190101', 3, 30)
insert into @product values ('Sand', '20190101', 1, 2)
insert into @product values ('Clay', '20190101', 1, 15)


Select [date], Clay, Mixed, Sand, Sandy
FROM(
SELECT 
    [Soil Type], [Month/Year] as [date],
    SUM([Volume]) / SUM([Total Hour]) as _data
FROM 
   @product
GROUP BY 
    [Soil Type], [Month/Year]
HAVING SUM([Volume])>30) x
PIVOT (
  SUM(_data) FOR [Soil Type] IN (Clay, Mixed, Sand, Sandy)
) pvt
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58600559

复制
相关文章

相似问题

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