蔷薇525 发表于 2017-12-14 07:39:14

SQL Server字符串聚合拼接办法

  数据范例如下:

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

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

declare @tempTable table( int, nvarchar(100))  

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

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

  插入初始的聚合数据
  

updateTag:  

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

  
select * from @tempTable
  

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

SELECT , STUFF(  
(
SELECT ','+   
FROM test b
  
WHERE b.Type = a.Type
  
FOR XML PATH('')),1 ,1, '')
  
from Test a
  
group by
  

  至于这个函数用法,这里就不多解释了,希望以上两种方案对您有一点帮助或者启示!
页: [1]
查看完整版本: SQL Server字符串聚合拼接办法