> 数据库 > Oracle >

oracle实现多行合并的方法

本文实例讲述了oracle实现多行合并的方法。分享给大家供大家参考。具体分析如下:

在写sql时,经常会有将某列的字段合并起来,比如将某人名下每个月的工资列示,但是每个人只能占一行。

像这种场景,可能用行列转换也能实现,但如果这个月份的信息不固定,就无法使用行列转换了。

oracle10g以后,提供了一个函数WMSYS.WM_CONCAT,能很轻松实现该功能。
 

select t.rank, WMSYS.WM_CONCAT(t.Name) TIME From t_menu_item t GROUP BY t.rank;

 

这样,看着就舒服多了。

这个方法没出来之前,可能还需要自己写一个函数,稍微麻烦些。

(责任编辑:IT)