質問:
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 サイトの他の関連記事を参照してください。