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