首页 > 数据库 > mysql教程 > 如何在 SQL Server 中将行转置为列?

如何在 SQL Server 中将行转置为列?

Mary-Kate Olsen
发布: 2025-01-05 07:39:40
原创
584 人浏览过

How to Transpose Rows into Columns in SQL Server?

在 SQL Server 中将行转为列

在 SQL Server 中,可以通过多种方法实现行转列。除了利用游标读取行和填充列之外,这种转换还存在其他方法。

一种有效的方法是条件聚合。通过将 MAX() 函数与 CASE 语句结合使用,您可以根据标记 ID 将值分配给特定列,如以下查询所示:

SELECT TimeSeconds,
       COALESCE(MAX(CASE WHEN TagID = 'A1' THEN Value END), 'n/a') A1,
       COALESCE(MAX(CASE WHEN TagID = 'A2' THEN Value END), 'n/a') A2,
       COALESCE(MAX(CASE WHEN TagID = 'A3' THEN Value END), 'n/a') A3,
       COALESCE(MAX(CASE WHEN TagID = 'A4' THEN Value END), 'n/a') A4
  FROM table1
 GROUP BY TimeSeconds
登录后复制

或者,您可以通过允许空值来简化查询而不是 'n/a':

SELECT TimeSeconds,
       MAX(CASE WHEN TagID = 'A1' THEN Value END) A1,
       MAX(CASE WHEN TagID = 'A2' THEN Value END) A2,
       MAX(CASE WHEN TagID = 'A3' THEN Value END) A3,
       MAX(CASE WHEN TagID = 'A4' THEN Value END) A4
  FROM table1
 GROUP BY TimeSeconds
登录后复制

另一种方法涉及 PIVOT 运算符。它允许您根据指定值将行旋转为列:

SELECT TimeSeconds, A1, A2, A3, A4
  FROM
(
  SELECT TimeSeconds, TagID, Value
    FROM table1
) s
PIVOT
(
  MAX(Value) FOR TagID IN (A1, A2, A3, A4)
) p
登录后复制

如果标签 ID 值是动态的,则可以使用动态 SQL 来生成所需的查询。通过利用 STUFF() 和 FOR XML PATH() 函数,您可以动态构建列列表并在 PIVOT 查询中使用它:

DECLARE @cols NVARCHAR(MAX), @sql NVARCHAR(MAX)

SET @cols = STUFF((SELECT DISTINCT ',' + QUOTENAME(TagID)
            FROM Table1
            ORDER BY 1
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)'),1,1,'')

SET @sql = 'SELECT TimeSeconds, ' + @cols + '
              FROM
            (
              SELECT TimeSeconds, TagID, Value
                FROM table1
            ) s
            PIVOT
            (
              MAX(Value) FOR TagID IN (' + @cols + ')
            ) p'

EXECUTE(@sql)
登录后复制

这些方法提供了在 SQL 中将行转置为列的有效方法服务器,根据标签ID值的可用性和性质来满足不同的场景。

以上是如何在 SQL Server 中将行转置为列?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板