分組字符合并SQL語句 按某字段合并字符串之一(簡單合并)
標題:按某字段合并字符串之一(簡單合并)
描述:將如下形式的數(shù)據(jù)按id字段合并value字段。
id value
----- ------
1 aa
1 bb
2 aaa
2 bbb
2 ccc
需要得到結果:
id value
------ -----------
1 aa,bb
2 aaa,bbb,ccc
即:group by id, 求 value 的和(字符串相加)
1、sql2000中只能用自定義的函數(shù)解決
create table tb(id int, value varchar(10)) insert into tb values(1, 'aa') insert into tb values(1, 'bb') insert into tb values(2, 'aaa') insert into tb values(2, 'bbb') insert into tb values(2,'ccc') go create function dbo.f_str(@id int) returns varchar(100) as begin declare @str varchar(1000) set @str='' select @str=@str+''+cast(value as varchar) from tb where id = @id set @str=right(@str , len(@str) - 1) return @str end go --調用函數(shù) select id , value = dbo.f_str(id) from tb group by id drop function dbo.f_str drop table tb
2、sql2005中的方法
create table tb(id int, value varchar(10)) insert into tb values(1, 'aa') insert into tb values(1, 'bb') insert into tb values(2, 'aaa') insert into tb values(2, 'bbb') insert into tb values(2, 'ccc') go select id, [value] = stuff((select ',' + [value] from tb t where id = tb.id for xml path('')) , 1 , 1 , '')from tb group by id drop table tb
3、使用游標合并數(shù)據(jù)
create table tb(id int, value varchar(10)) insert into tb values(1, 'aa') insert into tb values(1, 'bb') insert into tb values(2, 'aaa') insert into tb values(2, 'bbb') insert into tb values(2, 'ccc') go declare @t table(id int,value varchar(100)) --定義結果集表變量 --定義游標并進行合并處理 declare my_cursor cursor local for select id , value from tb declare @id_old int , @id int , @value varchar(10) , @s varchar(100) open my_cursor fetch my_cursor into @id , @value select @id_old = @id , @s=''while @@FETCH_STATUS = 0 begin if @id = @id_old select @s = @s + ',' + cast(@value as varchar) else begin insert @t values(@id_old , stuff(@s,1,1,'')) select @s = ',' + cast(@value as varchar) , @id_old = @id end fetch my_cursor into @id , @value END insert @t values(@id_old , stuff(@s,1,1,'')) close my_cursor deallocate my_cursor select * from @t drop table tb
以上就是關于分組字符合并SQL語句的介紹。希望對大家有所幫助。
相關文章
sql server數(shù)據(jù)庫中raiserror函數(shù)用法的詳細介紹
這篇文章主要介紹了sql server數(shù)據(jù)庫中raiserror函數(shù)用法的詳細介紹,raiserror用于拋出一個異常或錯誤,讓這個錯誤可以被程序捕捉到。對此感興趣的可以了解一下2020-07-07精妙的SQL和SQL SERVER 與ACCESS、EXCEL的數(shù)據(jù)導入導出轉換
sqlserver 與access,excel互相導入導出代碼2008-03-03SQL Server實現(xiàn)split函數(shù)分割字符串功能及用法示例
這篇文章主要介紹了SQL Server實現(xiàn)split函數(shù)分割字符串功能及用法,結合實例形式分析了SQL Server實現(xiàn)split分割字符串的相關技巧與使用方法,需要的朋友可以參考下2016-08-08通過T-SQL語句創(chuàng)建游標與實現(xiàn)數(shù)據(jù)庫加解密功能
這篇文章介紹了通過T-SQL語句創(chuàng)建游標與實現(xiàn)數(shù)據(jù)庫加解密功能的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-03-03由于系統(tǒng)錯誤 126 (SQL Server),指定驅動程序無法加載
今天下午在給客戶安裝用友T3標準版時碰到一個非常棘手的問題,MSDE2000數(shù)據(jù)庫和用友T3軟件都安裝好了,但是打開系統(tǒng)管理的時候提示:AUTOMATION錯誤,然后將數(shù)據(jù)庫徹底卸載干凈,用友通T3軟件也徹底卸載干凈,重新安裝了一下,仍然是這個情況2021-03-03SQL SERVER備份數(shù)據(jù)庫存儲過程的方法
這篇文章主要介紹了SQL SERVER備份數(shù)據(jù)庫存儲過程的方法,需要的朋友可以參考下2015-10-10