多行 合并为一行

wang7890 2008-10-23 11:13:20
表A 如下所示:

id name
1 zhang
2 wang
3 zhao
4 sun

我想合并为一行,如下所示:

1,2,3,4 zhang, wang,zhao,sun

怎么写这个语句? 请大家赐教!谢谢!
...全文
90 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
yonglinc 2008-10-23
  • 打赏
  • 举报
回复
学习
sleepzzzzz 2008-10-23
  • 打赏
  • 举报
回复
select wmsys.wm_concat(id)||' '||wmsys.wm_concat(name) from a
hebo2005 2008-10-23
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 linzhangs 的回复:]
SQL codeselect wmsys.wm_concat(id),wmsys.wm_concat(name) from a
[/Quote]
10G的用法
guojh021 2008-10-23
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 linzhangs 的回复:]
SQL code
select wmsys.wm_concat(id),wmsys.wm_concat(name) from a


[/Quote]

这个很好.
willflyz 2008-10-23
  • 打赏
  • 举报
回复
楼上的方法比较独特,不过好象不太对哦.
因为没有环境自己没办法验证,呵呵..
范佩西_11 2008-10-23
  • 打赏
  • 举报
回复
select wmsys.wm_concat(id),wmsys.wm_concat(name) from a
guojh021 2008-10-23
  • 打赏
  • 举报
回复
来自:oracledbalgtu
给你个参考方法:
SELECT DEPTNO, MAX(ONCATENATED)
FROM (SELECT DEPTNO,
LTRIM(SYS_CONNECT_BY_PATH(ENAME, ','), ',') ONCATENATED
FROM (SELECT DEPTNO,
ENAME,
ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY ENAME) AS CURR,
ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY ENAME) - 1 AS PREV
FROM SCOTT.EMP)
START WITH CURR = 1
CONNECT BY PREV = PRIOR CURR
AND DEPTNO = PRIOR DEPTNO)
GROUP BY DEPTNO
ORDER BY 1;
gisinfo 2008-10-23
  • 打赏
  • 举报
回复
select wmsys.wm_concat(id),wmsys.wm_concat(name) from a


在10G以上版本

17,134

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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