首頁 > 資料庫 > 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
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板