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

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Dreamweaver Mac版
视觉化网页开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 Linux新版
SublimeText3 Linux最新版