利用SQL对数据库实行数据拆分与组合实现提供以下几种方案:方法一:WITH CTE AS ( SELECT A.Id,A.[Uid],UserName FROM ( SELECT A.[id], REPLACE(Split.a.value(".", "NVARCHAR(max)"),"""","") AS [Uid] FROM ( SELECT [id], CAST ("<M>" + REPLACE(Uid, ",", "</M><M>") + "</M>" AS XML) AS [Uid] FROM A ) AS A CROSS APPLY [Uid].nodes ("/M") AS Split(a)) A INNER JOIN dbo.B B ON A.[Uid]=B.[Uid] ) SELECT DISTINCT classList=stuff((select "," +UserName from CTE B WHERE A.Id=B.Id for xml path("")),1,1,"") FROM CTE A 方法二:SELECT t.id,classList=STUFF(( SELECT ","+tt1.UserName FROM A tt left join B tt1 ON ""+tt.Uid+"," like "%"+tt1.Uid+",%" WHERE tt.id=t.id FOR XML PATH("")),1,1,"") FROM A t ORDER BY t.id方法三:select id, (select UserName from B where Uid=t02.item) c into #ttt from dbo.A as t01 cross apply dbo.split(t01.Uid,",") as t02select id,stuff((select ","+c from dbo.#ttt as tb01 where tb01.id=tb02.id for xml path("")),1,1,"") as classListfrom dbo.#ttt as tb02 group by iddrop table #ttt方法三需要添加内置方法:create function split( @string varchar(255), @separator varchar(255) )returns @array table(item varchar(255)) as begin declare @begin int,@end int,@item varchar(255) set @begin = 1 set @end=charindex(@separator,@string,@begin) while(@end<>0) begin set @item = substring(@string,@begin,@end-@begin) insert into @array(item) values(@item) set @begin = @end+1 set @end=charindex(@separator,@string,@begin) end set @item = substring(@string,@begin,len(@string)+1-@begin) if (len(@item)>0) insert into @array(item) values(substring(@string,@begin,len(@string)+1-@begin)) return end下面们直接看结果吧:表A:表B:最终结果:跟根据讨论给出的方法,我个人给出这样的三种,如果有不对之处,请多多指教。本文永久更新链接地址