首頁 >資料庫 >mysql教程 >如何在不使用 FOR XML 或 CLR 函數的情況下有效連接 SQL Server 中多行的字串?

如何在不使用 FOR XML 或 CLR 函數的情況下有效連接 SQL Server 中多行的字串?

DDD
DDD原創
2025-01-20 09:12:11920瀏覽

How Can I Efficiently Concatenate Strings from Multiple Rows in SQL Server Without Using FOR XML or CLR Functions?

SQL Server字串連線方法

問題描述:

您需要將多行中的字串聚合到單行中。 COALESCE和FOR XML無法滿足您的需求,且Azure不支援CLR定義的聚合函數。您需要尋找最佳的替代方案。

解:

使用標準Transact SQL,您可以透過以下步驟有效地連接字串:

  1. 編號行:基於分組標準對資料進行分區,並在每個分區內分配行號。
  2. 遞歸連接:建立一個遞歸CTE,根據行號迭代連接字串。
  3. 篩選結果:只選擇具有最高行號的結果,確保完整的連接。

說明:

此方法使用三個CTE:

  • Partitioned:為每個分區內的行分配行號。
  • Concatenated:遞歸建構連接的字串。
  • Final Result:篩選連接的行,只包含完整的結果。

要使用此解決方案,您必須指定分組和排序標準。例如,在您的情況下,具有相同ID的行會按字母順序連接和排序。

範例:

考慮以下數據:

<code>ID  Name
-- --
1   Matt
1   Rocks
2   Stylus
3   Foo
3   Bar
3   Baz</code>

查詢及其輸出如下:

<code class="language-sql">WITH Partitioned AS
(
    SELECT 
        ID,
        Name,
        ROW_NUMBER() OVER (PARTITION BY ID ORDER BY Name) AS NameNumber,
        COUNT(*) OVER (PARTITION BY ID) AS NameCount
    FROM dbo.SourceTable
),
Concatenated AS
(
    SELECT 
        ID, 
        CAST(Name AS nvarchar(max)) AS FullName, 
        Name, 
        NameNumber, 
        NameCount 
    FROM Partitioned 
    WHERE NameNumber = 1

    UNION ALL

    SELECT 
        P.ID, 
        CAST(C.FullName + ', ' + P.Name AS nvarchar(max)), 
        P.Name, 
        P.NameNumber, 
        P.NameCount
    FROM Partitioned AS P
        INNER JOIN Concatenated AS C 
                ON P.ID = C.ID 
                AND P.NameNumber = C.NameNumber + 1
)
SELECT 
    ID,
    FullName
FROM Concatenated
WHERE NameNumber = NameCount;</code>
<code>ID  FullName
-- ------------------------------
2   Stylus
3   Bar, Baz, Foo
1   Matt, Rocks</code>

改進說明:nvarchar類型改為nvarchar(max),以支援更長的字串連接結果。 這避免了潛在的字串長度溢出錯誤。

以上是如何在不使用 FOR XML 或 CLR 函數的情況下有效連接 SQL Server 中多行的字串?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn