1. 程式人生 > >SQL Server字串聚合拼接辦法

SQL Server字串聚合拼接辦法

文章原地址:https://www.cnblogs.com/stealth7/p/6891211.html

資料範例如下:

要得到的結果目標,獲取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 @tempTabl

迴圈插入其他滿足條件的聚合資料,這種方案適合包含聚合條件比較複雜的情況,比如需要查詢聚合多列拼接字串結果,其中還涉及到一些列的複雜運算,但是劣勢也很明顯,如果分組聚合的項比較多時,會比較耗時,因為有一個迴圈效率不是很高的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]

至於這個函式用法,這裡就不多解釋了,希望以上兩種方案對您有一點幫助或者啟示!