MySQL では、特定の列でグループ化された値を連結するために GROUP_CONCAT 関数が広く使用されています。 Oracle は、代替手段を通じて同様の機能を提供します:
<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 |
<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>
注: 大きなデータセットを処理するときにメモリの問題が発生する可能性があるため、この関数は注意して使用してください。
Oracle の一部の古いバージョンでは、WM_CONCAT と呼ばれるサポートされていない関数が提供されています。ただし、最新の Oracle バージョンでは LISTAGG またはカスタム関数を使用することをお勧めします。
完全を期すために、MySQL GROUP_CONCAT クエリを以下に示します。
<code class="language-sql">SELECT col1, GROUP_CONCAT(col2) FROM table_name GROUP BY col1;</code>
以上がOracle で MySQL の GROUP_CONCAT 機能を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。