将SQL里相同ID的数据放在一起用什么语句

变成下面图所示... 变成下面图所示 展开
 我来答
发生等将发生
推荐于2017-12-16 · TA获得超过478个赞
知道小有建树答主
回答量:653
采纳率:75%
帮助的人:323万
展开全部
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即可
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
micro0369
2014-09-16 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:3998万
展开全部

如果是oracle,有现成的函数:

   

select user,wmsys.wm_concat(tfbm) tfbm
from tabname
group by user

   


对于其他数据库,需要自己写函数,比如sqlserver,可以百度:sqlserver wm_concat,可以找到别人写好的函数

追问
搜到的不好用啊
追答
多试几个,总有好用的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
藜照堂_刘
2014-09-16 · TA获得超过5701个赞
知道小有建树答主
回答量:2034
采纳率:56%
帮助的人:350万
展开全部
select user,group_concat(tfbm) from table(表名) group by user
改成你的表名就行了
追问
这不是sqlsever的吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式