日期:2014-05-18 浏览次数:20560 次
create table tb(name varchar(10)) insert into tb select 'name1' union select 'name2' union select 'name3' union select 'name4' declare @str varchar(1000) select @str=ISNULL(@str+';','')+name from tb select @str /* ----------------------- name1;name2;name3;name4
------解决方案--------------------
---------------------------------------------------- /*如何将一列中所有的值一行显示 数据源 a b c d e 结果 a,b,c,d,e */ create table tb(col varchar(20)) insert tb values ('a') insert tb values ('b') insert tb values ('c') insert tb values ('d') insert tb values ('e') go --方法一 declare @sql varchar(1000) set @sql = '' select @sql = @sql + t.col + ',' from (select col from tb) as t set @sql='select result = ''' + left(@sql , len(@sql) - 1) + '''' exec(@sql) /* result ---------- a,b,c,d,e, */ --方法二 declare @output varchar(8000) select @output = coalesce(@output + ',' , '') + col from tb print @output /* a,b,c,d,e */ ---方法三 declare @s varchar(1000) select @s=isnull(@s+',' , '')+col from tb select @s /* a,b,c,d,e */ drop table tb -------------