这个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),在哪个表需要的时候调用并返回类似以上的结果就可以了?
...全文
44 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复

34,593

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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