一个临时表和一个光标跃入脑海......
亲爱的投票者:临时表和游标必须至少与上面接受的递归查询和自定义函数解决方案一样有效。克服对游标的恐惧,有时它们是最有效的解决方案。有时它们是唯一的解决方案。处理它。
编辑:下面基于光标的解决方案。请注意,它没有其他地方提出的非光标(并且更复杂)解决方案的限制,并且性能可能大致相同(当然很难从六行表中分辨出来)。
请不要仅仅因为某些博主说“这很糟糕”而放弃了 sql 的主要 for-each 构造;使用你自己的判断和一些常识。我尽可能避免使用游标,但不会到解决方案不可靠的地步。
--initial data table
create table #tmp (
id int,
subid int,
txt varchar(256)
)
--populate with sample data from original question
insert into #tmp (id,subid,txt) values (1, 1, 'Hello')
insert into #tmp (id,subid,txt) values (1, 2, 'World')
insert into #tmp (id,subid,txt) values (1, 3, '!')
insert into #tmp (id,subid,txt) values (2, 1, 'B')
insert into #tmp (id,subid,txt) values (2, 2, 'B')
insert into #tmp (id,subid,txt) values (2, 3, 'Q')
--temp table for grouping results
create table #tmpgrp (
id int,
txt varchar(4000)
)
--cursor for looping through data
declare cur cursor local for
select id, subid, txt from #tmp order by id, subid
declare @id int
declare @subid int
declare @txt varchar(256)
declare @curid int
declare @curtxt varchar(4000)
open cur
fetch next from cur into @id, @subid, @txt
set @curid = @id
set @curtxt = ''
while @@FETCH_STATUS = 0 begin
if @curid <> @id begin
insert into #tmpgrp (id,txt) values (@curid,@curtxt)
set @curid = @id
set @curtxt = ''
end
set @curtxt = @curtxt + isnull(@txt,'')
fetch next from cur into @id, @subid, @txt
end
insert into #tmpgrp (id,txt) values (@curid,@curtxt)
close cur
deallocate cur
--show output
select * from #tmpgrp
--drop temp tables
drop table #tmp
drop table #tmpgrp