在Oracle中,group_concat
函數(shù)并不是一個內(nèi)置的函數(shù),但你可以使用LISTAGG
函數(shù)來實現(xiàn)類似的功能
以下是一個示例,說明如何使用LISTAGG
函數(shù)處理空值:
SELECT department_id, LISTAGG(employee_name, ',') WITHIN GROUP (ORDER BY employee_name) AS employees
FROM (
SELECT department_id, employee_name,
ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY employee_name) AS rn
FROM employees
WHERE employee_name IS NOT NULL -- 過濾掉空值
)
GROUP BY department_id;
在這個示例中,我們首先使用子查詢過濾掉employee_name
為空的記錄。然后,我們使用LISTAGG
函數(shù)將每個部門的員工名字連接成一個字符串。最后,我們按照部門ID進行分組。
注意:在使用LISTAGG
函數(shù)時,如果結(jié)果字符串超過4000字節(jié),你需要使用CAST
函數(shù)將結(jié)果轉(zhuǎn)換為CLOB類型。例如:
SELECT department_id, CAST(COLLECT(employee_name) AS CLOB) AS employees
FROM (
SELECT department_id, employee_name,
ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY employee_name) AS rn
FROM employees
WHERE employee_name IS NOT NULL -- 過濾掉空值
)
GROUP BY department_id;
這里,我們使用CAST
函數(shù)將LISTAGG
函數(shù)的結(jié)果轉(zhuǎn)換為CLOB類型。