在 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中文网其他相关文章!