小编典典

从结果集中创建一个长字符串

sql

我在存储过程中的MS-
SQL中有一个结果集,可以说它有一个VARCHAR列,但有很多行。我想创建一个包含所有这些值的逗号分隔的字符串,是否有一种简单的方法来执行此操作,还是我必须逐步检查每个结果并手动构建字符串?

最好是我想在存储过程本身中执行此操作。


阅读 150

收藏
2021-04-22

共1个答案

小编典典

这是一种方法(使用AdventureWorks2008 DB):

DECLARE @name varchar(255)
SET @name = NULL

select @Name = COALESCE(@Name + ',','') + LastName from Person.Person
Select @name

这是另一个(从SQL 2005开始):

SELECT 
    LastName + ','
FROM 
    Person.Person
FOR XML PATH('')

在这两种情况下,您都需要删除逗号“,”(可以使用STUFF()函数)

2021-04-22