ホームページ > データベース > mysql チュートリアル > 古い Oracle バージョンには、MySQL の GROUP_CONCAT に相当する LISTAGG はありますか?

古い Oracle バージョンには、MySQL の GROUP_CONCAT に相当する LISTAGG はありますか?

Patricia Arquette
リリース: 2025-01-15 12:19:45
オリジナル
128 人が閲覧しました

Is There a LISTAGG Equivalent in Older Oracle Versions to MySQL's GROUP_CONCAT?

Oracle には MySQL の GROUP_CONCAT に相当するものはありますか?

質問:

Oracle で指定された列の複数の値を単一のカンマ区切り文字列に連結するにはどうすればよいですか?入力データは特定の形式に従い、目的の出力では一意のキーごとに値をグループ化して連結する必要があります。

答え:

Oracle 11g 以降の場合:

LISTAGG 関数を使用します:

<code class="language-sql">SELECT 
    col1,
    LISTAGG(col2, ', ') WITHIN GROUP (ORDER BY col2) "names"
FROM table_x
GROUP BY col1</code>
ログイン後にコピー

Oracle 10g 以前の場合:

1 つの方法は、カスタム関数を作成することです:

<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>
ログイン後にコピー

注: 11g より前の Oracle バージョンでは、WM_CONCAT 関数のサポートが制限されていますが、潜在的な問題があるため、その使用は非推奨です (詳細については、Oracle のドキュメントを参照してください)。

MySQL の場合 (参照のみ):

使用可能な GROUP_CONCAT 関数:

<code class="language-sql">SELECT col1, GROUP_CONCAT(col2) FROM table_name GROUP BY col1</code>
ログイン後にコピー

以上が古い Oracle バージョンには、MySQL の GROUP_CONCAT に相当する LISTAGG はありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート