将oracle 查询结果列拼接为字符串

表中的原始数据为idname1a1b1c2a2b3a3c.......现在想查询显示的结果为idname1a,b,c2a,b3a,c.......sql语句咋写在线等谢谢... 表中的原始数据为
id name
1 a
1 b
1 c
2 a
2 b
3 a
3 c
.......
现在想查询显示的结果为
id name
1 a,b,c
2 a,b
3 a,c
.......
sql语句咋写 在线等谢谢!急!!!!!
展开
 我来答
藏漂生活这几年
2012-05-17 · TA获得超过681个赞
知道小有建树答主
回答量:409
采纳率:33%
帮助的人:348万
展开全部
create table test (id int, name varchar(10) )
insert into test values (1,'a')
insert into test values (1,'b')
insert into test values (1,'c')
insert into test values (2,'a')
insert into test values (2,'b')
insert into test values (3,'a')
insert into test values (3,'c')

select id,sys_connect_by_path(name,',') from (
select id,name, row_number() over(partition by id order by name)rn,
count(*) over(partition by id ) cnt from test
) a where level=cnt
start with rn=1 connect by prior id=id and prior rn=rn-1

测试后 可用。

一楼的回答其实最容易理解了。你把它修改成动态sql 就可以了。可以不受限制了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
flyingFish211
2012-05-16 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
个数有限,可以实现
select id, max(case when rk = 1 then name else '' end)
||','||max(case when rk = 2 then name else '' end)
||','||max(case when rk = 3 then name else '' end)
from (SELECT id, name,row_number() over(partition by id order by name) rk from tab) t
group by id
追问
个数是不无限的,具体的值不确定,是根据关联关系出来的
追答
那自己写存储过程吧,sql不是万能的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
moreazy
2012-05-16 · TA获得超过742个赞
知道小有建树答主
回答量:274
采纳率:0%
帮助的人:131万
展开全部
select t.id, WMSYS.WM_CONCAT(t.Name) name From table_name t GROUP BY t.id
追问
中文会出现乱码,咋解决
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式