从结果集创建长字符串

时间:2008-11-17 13:40:07

标签: sql tsql string

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

我希望在存储过程本身中这样做。

2 个答案:

答案 0 :(得分:7)

这是一种方式(使用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()函数)

答案 1 :(得分:1)