温馨提示×

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

小亿
344
2023-10-24 10:42:00
栏目: 云计算

在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及以上版本才可用。

0