将 SQL 查询结果连接到单个字符串中
在 SQL 场景中,将查询结果合并到一个内聚字符串中可能会很有利。为了实现这一点,C# 程序员常用的一种方法是 FOR EACH 循环。然而,SQL 提供了另一种解决方案来完成此任务。
一种已被证明有效的方法是实施 FOR XML PATH & STUFF。此技术特别适合 SQL Server 2005 及后续版本。
此方法的语法如下:
DECLARE @CodeNameString varchar(100) SELECT @CodeNameString = STUFF( (SELECT ',' + CodeName FROM dbo.AccountCodes ORDER BY Sort FOR XML PATH('')), 1, 1, '')
FOR XML PATH('') 函数连接字符串结果到单个 XML 实体中。随后,STUFF 函数使用“无”字符删除初始逗号,最终生成所需的连接字符串。
处理特殊字符
需要注意的是, FOR XML PATH('') 方法在处理特殊字符(例如 或 &)时可能会遇到挑战。在这种情况下,替代解决方案是实现 @KM 在原始讨论中提出的 STRING_AGG() 函数。
资源注意事项
值得考虑的是,与 FOR XML PATH & STUFF 技术相比,STRING_AGG() 方法需要更多的资源和处理时间。因此,根据情况的具体要求评估合适的解决方案至关重要。
以上是如何有效地将 SQL 查询结果连接成单个字符串?的详细内容。更多信息请关注PHP中文网其他相关文章!