SQL Server字符串聚合拼接辦法
阿新 • • 發佈:2017-05-22
image code 聚合 個人 lec bsp log 希望 在一起
數據範例如下:
要得到的結果目標,獲取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 @tempTableset [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字符串聚合拼接辦法