SQL Server字符串聚合拼接办法

Posted 阿弥陀佛呵呵哒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server字符串聚合拼接办法相关的知识,希望对你有一定的参考价值。

数据范例如下:

要得到的结果目标,获取type相同的所有names拼接在一起的字符串:

SqlServer并没有一个直接拼接字符串的函数,下面所提到的方法,只是日常的开发中自己个人用到的一些思路,仅供参考!

declare @tempTable table([Type] int,[Name] nvarchar(100))

创建表变量,字段为你需要返回的各列的值

insert @tempTable
select [type],MAX([name]) name
from test
group by [type]

插入初始的聚合数据

updateTag:
update @tempTable
set [name] += (\',\'+ a.[name])
from test a,@tempTable b
where a.[Type] = B.[Type] 
and CHARINDEX(a.[name],b.[name]) = 0
if @@ROWCOUNT > 0
begin
    GOTO updateTag
end

select * from @tempTable

循环插入其他满足条件的聚合数据,这种方案适合包含聚合条件比较复杂的情况,比如需要查询聚合多列拼接字符串结果,其中还涉及到一些列的复杂运算,但是劣势也很明显,如果分组聚合的项比较多时,会比较耗时,因为有一个循环效率不是很高的insert,但是对于几十或者几百次的循环来说还是没太大的问题的。

 

其实网上搜了一圈还是有不错的方法的,比如STUFF函数,我们可以这么写得到上面的结果:

SELECT [TYPE], STUFF(
( SELECT \',\'+ [Name] 
FROM test b 
WHERE b.Type = a.Type 
FOR XML PATH(\'\')),1 ,1, \'\') [Names]
from Test a
group by [TYPE]

至于这个函数用法,这里就不多解释了,希望以上两种方案对您有一点帮助或者启示!

以上是关于SQL Server字符串聚合拼接办法的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server 自定义聚合函数

SQLserver字符型数据在哪里

sql server 的存储过程字符串怎么拼接的

Sql Server将一列字段拼接成字符串方法

sqlserver中怎么将一列数据拼接成一个字符串

SQL Server2000将一列数据拼接成字符串可以用STUFF FOR XML PATH()么