我在存储过程中的MS-SQL中有一个结果集,并且假设它有一个VARCHAR列,但是有很多行.我想创建一个逗号分隔的字符串,包含所有这些值,是否有一个简单的方法,或者我将不得不逐步完成每个结果并手动构建字符串?
我想在存储过程本身中这样做.
这是一种方法(使用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()函数)