首頁 >資料庫 >mysql教程 >如何在Oracle中實現MySQL的GROUP_CONCAT功能?

如何在Oracle中實現MySQL的GROUP_CONCAT功能?

Susan Sarandon
Susan Sarandon原創
2025-01-15 12:32:44369瀏覽

How to Achieve MySQL's GROUP_CONCAT Functionality in Oracle?

Oracle 中的 SQL 分組連接:MySQL 的 GROUP_CONCAT 的等效項

在 MySQL 中,GROUP_CONCAT 函數廣泛用於連接以特定列分組的值。 Oracle 透過替代方法提供類似的功能:

LISTAGG 函數(11g 及更高版本)

<code class="language-sql">SELECT col1,
       LISTAGG(col2, ', ') WITHIN GROUP (ORDER BY col2) AS "names"
FROM table_x
GROUP BY col1;</code>

輸出:

col1 names
1 a, b
2 c, d, e

自訂函數(10g 及更低版本)

<code class="language-sql">CREATE OR REPLACE FUNCTION get_comma_separated_value(input_val NUMBER)
  RETURN VARCHAR2
IS
  return_text VARCHAR2(10000) := NULL;
BEGIN
  FOR x IN (SELECT col2 FROM table_name WHERE col1 = input_val) LOOP
    return_text := return_text || ',' || x.col2;
  END LOOP;
  RETURN LTRIM(return_text, ',');
END;
/</code>

使用函數的查詢:

<code class="language-sql">SELECT col1, get_comma_separated_value(col1) FROM table_name;</code>

注意: 使用此函數時要謹慎,因為它在處理大型資料集時可能會遇到記憶體問題。

WM_CONCAT 函數(不支援)

某些較舊版本的 Oracle 提供了一個名為 WM_CONCAT 的不支援的函數。但是,建議對於現代 Oracle 版本使用 LISTAGG 或自訂函數。

MySQL GROUP_CONCAT 等效項

為完整起見,以下提供了 MySQL GROUP_CONCAT 查詢:

<code class="language-sql">SELECT col1, GROUP_CONCAT(col2) FROM table_name GROUP BY col1;</code>

以上是如何在Oracle中實現MySQL的GROUP_CONCAT功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn