[求]行列转换、合并====带表名,列名变量处理方法====

smalldeer 2004-02-12 03:55:39
原帖如下
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,所以想到用存储过程来代替函数。
自己功力不够,调不出来,特发帖求助

谢谢大家


...全文
54 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧