3个回答
展开全部
create function pj(@id int)
returns varchar(200)
as
begin
declare @tfbm varchar(200)
select @tfbm isnull(@tfbm,'') + ',' from table
where id = @id
return left(@tfbm,len(@tfbm) - 1)
end
go
select k.id,dbo.pj(k.id) from (
select id from table
group by id) k
试试看行不行,具体思路就是:
1、创建函数,将一个ID的所有tfbm值拼接在一起,并返回
2、将数据按照ID分组,使每个ID都唯一,然后查询,在查询时,调用函数,将其当做列,传ID即可
returns varchar(200)
as
begin
declare @tfbm varchar(200)
select @tfbm isnull(@tfbm,'') + ',' from table
where id = @id
return left(@tfbm,len(@tfbm) - 1)
end
go
select k.id,dbo.pj(k.id) from (
select id from table
group by id) k
试试看行不行,具体思路就是:
1、创建函数,将一个ID的所有tfbm值拼接在一起,并返回
2、将数据按照ID分组,使每个ID都唯一,然后查询,在查询时,调用函数,将其当做列,传ID即可
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果是oracle,有现成的函数:
select user,wmsys.wm_concat(tfbm) tfbm
from tabname
group by user
对于其他数据库,需要自己写函数,比如sqlserver,可以百度:sqlserver wm_concat,可以找到别人写好的函数
追问
搜到的不好用啊
追答
多试几个,总有好用的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select user,group_concat(tfbm) from table(表名) group by user
改成你的表名就行了
改成你的表名就行了
追问
这不是sqlsever的吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询