首頁 >資料庫 >mysql教程 >如何在 SQL Server 中有效地連接子查詢中的行?

如何在 SQL Server 中有效地連接子查詢中的行?

Linda Hamilton
Linda Hamilton原創
2025-01-22 00:15:10842瀏覽

How Can I Efficiently Concatenate Rows from a Subquery in SQL Server?

SQL Server 行串聯:自訂函數與現代方法

本文示範了兩種有效連接 SQL Server 中子查詢中的行的方法,從而產生單一分隔字串。 第一個使用自訂函數,提供跨各種 SQL Server 版本的兼容性。第二個利用 SQL Server 2017 及更高版本中提供的 STRING_AGG 函數來提供增強的效能。

方法一:JoinRows使用者定義函數

為了更廣泛的 SQL Server 版本相容性,自訂函數提供了一個乾淨的解決方案。 下面的 JoinRows 函數採用分隔符號和表格作為輸入,傳回一個連接字串:

<code class="language-sql">CREATE FUNCTION JoinRows (
    @Separator CHAR(1),
    @InputTable TABLE (ID INT, Value VARCHAR(MAX))
)
RETURNS VARCHAR(MAX)
BEGIN
    RETURN (
        SELECT COALESCE(@Separator + I.Value, I.Value)
        FROM @InputTable AS I
        FOR XML PATH('')
    );
END;</code>

此功能可以整合到您的查詢中,如下所示:

<code class="language-sql">SELECT
    VehicleID,
    Name,
    JoinRows(', ', (SELECT City FROM Location WHERE VehicleID = Vehicles.VehicleID)) AS Locations
FROM Vehicles;</code>

方法 2:STRING_AGG(SQL Server 2017 及更高版本)

對於 SQL Server 2017 及後續版本,內建 STRING_AGG 函數提供了更簡化且通常更快的方法:

<code class="language-sql">SELECT
    VehicleID,
    Name,
    STRING_AGG(City, ', ') WITHIN GROUP (ORDER BY City) AS Locations
FROM Vehicles
INNER JOIN Location ON Vehicles.VehicleID = Location.VehicleID
GROUP BY VehicleID, Name;</code>

此方法直接連接 VehiclesLocation 表,並使用 STRING_AGG 聚合 City 值,按 VehicleID 分割區,為較新的 SQL Server 執行個體提供更有效率的解決方案。 請注意新增 WITHIN GROUP (ORDER BY City) 以實現連接城市的可預測排序。 這是可選的,但建議這樣做以獲得一致的結果。 GROUP BY 子句對於確保正確聚合也是必要的。

選擇最適合您的 SQL Server 版本和效能要求的方法。 對於舊版本,需要自訂功能;對於較新的版本,STRING_AGG 提供了顯著的效能優勢。

以上是如何在 SQL Server 中有效地連接子查詢中的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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