这个SQL语句应该如何写?
bqj 2004-02-11 10:28:31 有表内容如下:
A B
INV001 PARTNAME1
INV001 PARTNAME2
INV001 PARTNAME1
INV002 PARTNAME1
INV002 PARTNAME3
INV003 PARTNAME2
....
....
如何用SQL语句将上表转为以下形式:
A B
INV001 PARTNAME1,PARTNAME2
INV002 PARTNAME1,PARTNAME3
INV003 PARTNAME2
....
....
smalldeer有以下解答,经测试是正确的,十分感谢!
create table INV(
A varchar(10),
B varchar(10)
)
go
insert into INV values('INV001','PARTNAME1')
insert into INV values('INV001','PARTNAME2')
insert into INV values('INV001','PARTNAME1')
insert into INV values('INV002','PARTNAME1')
insert into INV values('INV002','PARTNAME3')
insert into INV values('INV003','PARTNAME2')
alter function f_INV(@A varchar(10))
returns varchar(8000)
as
begin
declare @re varchar(8000)
set @re=''
select @re=@re+','+B from INV where A=@A group by A,B
set @re=substring(@re,2,8000)
return(@re)
end
go
---------------测试-----------------
select A,B=dbo.f_INV(A)
from INV
group by A
-----------------------------------
INV001 PARTNAME1,PARTNAME2
INV002 PARTNAME1,PARTNAME3
INV003 PARTNAME2
在此基础上,另有一个问题,如何将该函数做成一个通用的函数,比如参数包括表名(tablename)、主键字段(如上例中的A)、合并的字段(如上例中的B),在哪个表需要的时候调用并返回类似以上的结果就可以了?