Oracle中如何查询多个值并合在一行
在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及以上版本才可用。
TOP