日期:2014-05-18  浏览次数:20533 次

求SQL語句???
表名:table1
其中的字段為:Name 
存在如下記錄:nameA
  nameB
  nameC
  nameD
  nameE

想得到如下結果:“nameA;nameB; nameC;nameD; nameE”



怎麼做??????十分感謝

------解决方案--------------------
SQL code
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

------解决方案--------------------
SQL code
----------------------------------------------------
/*如何将一列中所有的值一行显示
数据源
  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


-------------