首页 >数据库 >mysql教程 >如何在 SQL Server 中有效地连接子查询中的行?

如何在 SQL Server 中有效地连接子查询中的行?

Linda Hamilton
Linda Hamilton原创
2025-01-22 00:15:10845浏览

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