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中文网其他相关文章!