首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Unpivot子查询

Unpivot子查询
EN

Stack Overflow用户
提问于 2020-06-24 18:59:47
回答 1查看 383关注 0票数 1

我需要将这个查询结果转换成行而不是列。使用Un透视是可能的,但我无法执行此活动,请参阅代码:

代码语言:javascript
复制
    SELECT
cast(IIF(DATEPART(HOUR, [DATA]) <= 4, DATEADD(DAY, -1, [DATA]), [DATA]) as date) as Data,
IIF(DATEPART(HOUR, [DATA]) <= 4, DATEADD(DAY, -1, [DATA]), [DATA]) AS DataHora,
SUM([FraturaContusao]) AS 'FraturaContusao',
SUM([Salpingite]) AS 'Salpingite'
FROM
(
    SELECT
        [DATA], ROMANEIO,
        IIF(( bAbaco.FRATURA_CONTUSAO - COALESCE(LAG(bAbaco.FRATURA_CONTUSAO) OVER (ORDER BY bAbaco.ID), 0)) > 0 , ( bAbaco.FRATURA_CONTUSAO - COALESCE(LAG(bAbaco.FRATURA_CONTUSAO) OVER ( ORDER BY bAbaco.ID), 0)), 0) AS 'FraturaContusao',
        IIF(( bAbaco.Salpingite - COALESCE(LAG(bAbaco.Salpingite) OVER (ORDER BY bAbaco.ID), 0)) > 0 , ( bAbaco.Salpingite - COALESCE(LAG(bAbaco.Salpingite) OVER ( ORDER BY bAbaco.ID), 0)), 0) AS 'Salpingite'
    FROM
    ContProdUIA.ABACO_DIGITAL_L2 bAbaco
    ) as x
WHERE
CONVERT(varchar, x.[DATA], 23) >= DATEADD(DAY, -16, GETDATE())
GROUP BY 
IIF(DATEPART(HOUR, [DATA]) <= 4, DATEADD(DAY, -1, [DATA]), [DATA])

这是查询的结果:

我需要将列'FraturaContusao‘和'Salpingite’转换为unpviot,如下所示:

代码语言:javascript
复制
Data| DataHora | Tipo| Qty
2020-06-23 | 2020-06-23 15:54 | FraturaContusao| 15
2020-06-23 | 2020-06-23 15:54 | Salpingite | 20
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-24 19:59:27

也许最简单的方法是使用CROSS APPLY

示例

代码语言:javascript
复制
 Select A.Data
       ,A.DataHora
       ,B.Tipo
       ,B.Qty
 From  (
         -- your orignal query here --
       ) A
 Cross Apply ( values ('FraturaContusao',FraturaContusao)
                     ,('Salpingite'     ,Salpingite)
             ) B(Tipo,Qty)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62562272

复制
相关文章

相似问题

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