企业如何通过vue小程序开发满足高效运营与合规性需求
473
2023-11-26
本文小编为大家详细介绍“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 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)gocreate function dbo.f_str(@id int) returns varchar(100)asbegin 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 @strendgo--调用函数select id , value = dbo.f_str(id) from tb group by iddrop function dbo.f_strdrop table tb2、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)goselect id, [value] = stuff((select , + [value] from tb t where id = tb.id for xml path()) , 1 , 1 , )from tb group by iddrop table tb3、使用游标合并数据
create table tb(id int, value varchar(10))insert into tbvalues(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)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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~