[求]行列转换、合并====带表名,列名变量处理方法====
原帖如下
http://expert.csdn.net/Expert/topic/2721/2721921.xml?temp=8.265322E-02
有表内容如下:
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
....
....
------------------------------------------
--测试环境
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')
create 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
这个是照着[交流]行列转换(txlicenhe)里面的方法
现在要处理的是=====================
如何将该函数做成一个通用的函数,比如参数包括表名(tablename)、主键字段(如上例中的A)、合并的字段(如上例中的B),在哪个表需要的时候调用并返回类似以上的结果就可以了?
昨天也调试了很久,没有出来结果
主要卡在函数中不能用exec,所以想到用存储过程来代替函数。
自己功力不够,调不出来,特发帖求助
谢谢大家