SQL Server 行串聯:自訂函數與現代方法
本文示範了兩種有效連接 SQL Server 中子查詢中的行的方法,從而產生單一分隔字串。 第一個使用自訂函數,提供跨各種 SQL Server 版本的兼容性。第二個利用 SQL Server 2017 及更高版本中提供的 STRING_AGG
函數來提供增強的效能。
方法一:JoinRows
使用者定義函數
為了更廣泛的 SQL Server 版本相容性,自訂函數提供了一個乾淨的解決方案。 下面的 JoinRows
函數採用分隔符號和表格作為輸入,傳回一個連接字串:
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;
此功能可以整合到您的查詢中,如下所示:
SELECT VehicleID, Name, JoinRows(', ', (SELECT City FROM Location WHERE VehicleID = Vehicles.VehicleID)) AS Locations FROM Vehicles;
方法 2:STRING_AGG
(SQL Server 2017 及更高版本)
對於 SQL Server 2017 及後續版本,內建 STRING_AGG
函數提供了更簡化且通常更快的方法:
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;
此方法直接連接 Vehicles
和 Location
表,並使用 STRING_AGG
聚合 City
值,按 VehicleID
分割區,為較新的 SQL Server 執行個體提供更有效率的解決方案。 請注意新增 WITHIN GROUP (ORDER BY City)
以實現連接城市的可預測排序。 這是可選的,但建議這樣做以獲得一致的結果。 GROUP BY
子句對於確保正確聚合也是必要的。
選擇最適合您的 SQL Server 版本和效能要求的方法。 對於舊版本,需要自訂功能;對於較新的版本,STRING_AGG
提供了顯著的效能優勢。
以上是如何在 SQL Server 中有效地連接子查詢中的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!