在Oracle中,可以使用LISTAGG
函数将多个值合并成一行。
例如,有一个名为employees
的表,包含employee_id
和employee_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及以上版本才可用。