SQL怎么按某字段合并字符串

网友投稿 421 2023-11-26

SQL怎么按某字段合并字符串

本文小编为大家详细介绍“SQL怎么按某字段合并字符串”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL怎么按某字段合并字符串”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

SQL怎么按某字段合并字符串

标题:按某字段合并字符串之一(简单合并)

描述:将如下形式的数据按id字段合并value字段。id value----- ------1 aa1 bb2 aaa2 bbb2 ccc需要得到结果:id value------ -----------1 aa,bb2 aaa,bbb,ccc即:group by id, 求 value 的和(字符串相加)

1、sql2000中只能用自定义的函数解决

create table tb(id intvalue varchar(10))insert into tb values(1aa)insert into tb values(1bb)insert into tb values(2aaa)insert into tb values(2bbb)insert into tb values(2,ccc)gocreate function dbo.f_str(@id intreturns varchar(100)asbegin declare @str varchar(1000set @strselect @str=@str++cast(value as varcharfrom tb where id = @id set @str=right(@str , len(@str) - 1return @strendgo--调用函数select id , value = dbo.f_str(id) from tb group by iddrop function dbo.f_strdrop table tb

2、sql2005中的方法

create table tb(id intvalue varchar(10))insert into tb values(1aa)insert into tb values(1bb)insert into tb values(2aaa)insert into tb values(2bbb)insert into tb values(2ccc)goselect id, [value] = stuff((select , + [valuefrom tb t where id = tb.id for xml path()) , 1 , 1 , )from tb group by iddrop table tb

3、使用游标合并数据

create table tb(id int, value varchar(10))insert into tbvalues(1aa)insert into tb values(1bb)insert into tb values(2aaa)insert into tb values(2bbb)insert into tb values(2ccc)godeclare @t table(id int,value varchar(100))--定义结果集表变量--定义游标并进行合并处理declare my_cursor cursorlocal forselect id , value from tbdeclare @id_old int , @id int , @value varchar(10) , @s varchar(100)open my_cursor fetch my_cursor into @id , @valueselect @id_old = @id , @s=while@@FETCH_STATUS = 0beginif @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 @tvalues(@id_old , stuff(@s,1,1,)) close my_cursor deallocate my_cursor select * from @tdrop table tb

读到这里,这篇“SQL怎么按某字段合并字符串”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:行式数据库 VS 列式数据库
下一篇:实时数据库与时序数据库
相关文章

 发表评论

暂时没有评论,来抢沙发吧~