ホームページ >データベース >mysql チュートリアル >Oracle で GROUP_CONCAT 機能を実現するにはどうすればよいですか?

Oracle で GROUP_CONCAT 機能を実現するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2025-01-15 12:28:44428ブラウズ

How to Achieve GROUP_CONCAT Functionality in Oracle?

Oracle でのグループ結合操作

MySQL の GROUP_CONCAT 関数は、複数の行のグループ化された値を文字列に連結できます。 Oracle にはまったく同等の機能はありませんが、同様の機能を実現する方法がいくつかあります。

Oracle 11g 以降では LISTAGG を使用します

Oracle 11g では、値をカンマ区切りの文字列に集計する LISTAGG 関数が導入されました。

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

Oracle 10g 以前のバージョンはカスタム関数を使用します

Oracle 10g 以前の場合、カスタム関数を作成できます:

<code class="language-sql">CREATE OR REPLACE FUNCTION get_comma_separated_value (input_val IN 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>

注: 一部の古い Oracle バージョンでは、(サポートされていない) 関数 WM_CONCAT が使用できます。

MySQL の代替方法 (比較用)

MySQL では、GROUP_CONCAT 関数を使用できます:

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

以上がOracle で GROUP_CONCAT 機能を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。