Oracle中怎么查询多个值并合在一行

avatar
作者
筋斗云
阅读量:1

在Oracle中,可以使用LISTAGG函数将多个值合并成一行。

例如,有一个名为employees的表,包含employee_idemployee_name两个列,我们想要将所有员工的姓名合并成一行,可以使用以下查询:

SELECT LISTAGG(employee_name, ', ') WITHIN GROUP (ORDER BY employee_id) AS all_employee_names FROM employees; 

以上查询会将所有员工的姓名以逗号分隔的形式合并成一行,并按照employee_id的顺序进行排序。结果将会以all_employee_names作为列名返回。

如果要将多个列的值合并成一行,可以在LISTAGG函数中指定多个列名,并使用字符串拼接函数(如CONCAT)将它们连接起来。

注意:LISTAGG函数在Oracle 11g及以上版本才可用。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!