RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1321837
Accepted
Insider
Insider
Asked:2022-08-27 16:50:18 +0000 UTC2022-08-27 16:50:18 +0000 UTC 2022-08-27 16:50:18 +0000 UTC

MSSQL 将行翻转到列

  • 772

寻找一种在 MSSQL 中将行翻转为列的方法。这就是我的桌子的样子:

在此处输入图像描述

试图这样做

SELECT ta.AuftragID,
  SUM(CASE 
    WHEN [Abteilung] = 'Konstruktion' THEN [PlanAufwand]
  END) AS Konstruktion, 
  SUM(CASE 
    WHEN [Abteilung] = 'Mechanik' THEN [PlanAufwand]
  END) AS Mechanik,
  SUM(CASE 
    WHEN [Abteilung] = 'Verdrahtung' THEN [PlanAufwand]
  END) AS Verdrahtung
FROM Terminliste_Abteilungsablauf ta

但是,由于 AuftragID 不止一次花费,我得到了这样的东西 在此处输入图像描述

结果应该是这样的,也许有人有解决方案。

AuftragsID Konstruktion Mechanik Verdrahtung
22103776      10            10       10
22103777       5             2       1

示例 https://data.stackexchange.com/stackoverflow/query/1453280/pivot

sql
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    Skate_banana
    2022-08-27T17:57:27Z2022-08-27T17:57:27Z

    使用动态 SQL,因此每次表内容更改时,PIVOT 都不会被重写。

    drop table if exists #Table1
    
    create table #Table1
    (
        AuftragID bigint not null,
        Abteilung nvarchar(200) not null,
        PlanAufwand int
    );
    
    insert into #Table1 (AuftragID, Abteilung, PlanAufwand)
    values
    (22103776, 'bestuck', null),
    (22103776, 'cnc', null),
    (22103776, 'diverses', null),
    (22103776, 'fastlane', null),
    (22103776, 'konstruktion', null),
    (22103776, 'mechanic', null),
    (22103776, 'qualitajdcnoenvowcv', null),
    (22103776, 'verdrahtung', null),
    (22103777, 'arbeiten', 2),
    (22103777, 'bestuck', 2),
    (22103777, 'cnc', 5),
    (22103777, 'diverses', null),
    (22103777, 'fastlane', null),
    (22103777, 'konstruktion', 7),
    (22103777, 'mechanic', 7),
    (22103777, 'qualitajdcnoenvowcv', 2),
    (22103777, 'verdrahtung', 3)
    --,(22103778, 'NOVOE_ZNACHENIE', 5), 
    --(22103776, 'NOVOE_ZNACHENIE', 2),     ---при добавлении новых значений в таблицу, они будут автоматом попадать в запрос с PIVOT'ом
    --(22103777, 'NOVOE_ZNACHENIE', null)
    
    declare @val1 nvarchar(max);
    declare @val nvarchar(max);
    declare @company table ([name] nvarchar(max), num int identity (1,1));
    declare @select nvarchar(max);
    
    insert into @company ([name])
    select distinct Abteilung as [name] 
    from #Table1;
    
    
    set @val = 
    (select stuff((select ',' + [name]
                   from @company
                   for xml path('')
                  ), 1, 1, '')
    );
    
    
    set @val1 = 
    (select stuff((select ', isnull(' + [name] + ', ''0'') as '+ [name]
                   from @company
                   for xml path('')
                  ), 1, 1, '')
    );
    
    
    set @select = 'select AuftragID, ' + @val1 +
    ' from 
        (
            select AuftragID, sum(PlanAufwand) as sumorder, Abteilung as [name]
            from #Table1
            group by AuftragID, Abteilung
        ) t
        pivot(sum(sumorder)
                for [name]
                    IN (' + @val + ')
                ) as d';
    
    
    exec (@select)
    
    • 3
  2. Akina
    2022-08-27T17:47:00Z2022-08-27T17:47:00Z

    你的方式:

    SELECT ta.Auftrag,
      MAX( CASE WHEN [Abteilung] = 'Konstruktion' 
                THEN [PlanAufwand]
                END ) AS Konstruktion, 
      MAX( CASE WHEN [Abteilung] = 'Mechanik' 
                THEN [PlanAufwand]
                END ) AS Mechanik,
      MAX( CASE WHEN [Abteilung] = 'Verdrahtung' 
                THEN [PlanAufwand]
                END ) AS Verdrahtung
    FROM #yourtable  ta
    GROUP BY Auftrag
    

    通过汇总查询:

    SELECT Auftrag, Konstruktion, Mechanik, Verdrahtung
    FROM #yourtable
    PIVOT
    (
        MAX(PlanAufwand) -- может, тут должно быть SUM() ?
        FOR Abteilung IN (Konstruktion, Mechanik, Verdrahtung)
    ) AS PivotTable; 
    

    https://dbfiddle.uk/?rdbms=sqlserver_2017&fiddle=48c33fcbf9fb3a9f8e21eca72b27ff67

    • 1

相关问题

  • 通过 OUT 参数从过程结果输出

  • ON 关键字附近的语法错误 - SQL

  • 多表查询中的 Count() 聚合函数

  • 根据时间更改单元格中的日期

  • phpMyAdmin 中的错误 #1064 SQL 查询

  • Qt:包含变量的数据库查询

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5