Oracle データベースでは、テーブル内の複数の行を 1 つの行にマージして、複数の列を含むテーブル構造を作成する必要がある場合があります。次のスキーマを持つテーブルがあるとします:
<code>A 1 A 2 B 1 B 2</code>
次の期待される結果を達成するには:
<code>A 1 2 B 1 2</code>
Oracle は、このニーズを満たすために特定の SQL 関数を提供します。
警告: WM_CONCAT 関数は現在非推奨であり、Oracle 12c 以降では削除されています。それ以降のバージョンで使用すると、予期しない結果が発生する可能性があります。
<code class="language-sql">SELECT field1, WM_CONCAT(field2) FROM YourTable GROUP BY field2;</code>
新しい Oracle バージョンの場合は、LISTAGG 関数を使用することをお勧めします。
<code class="language-sql">SELECT field1, LISTAGG(field2, ',') WITHIN GROUP (ORDER BY field2) FROM YourTable GROUP BY field1;</code>
WM_CONCAT 関数も LISTAGG 関数も使用している Oracle のバージョンで使用できない場合は、次の手順に従ってカスタム集計を実装できます。
カスタム集計は、事前定義された関数を使用する場合よりも複雑で、計算量が多くなる場合があることに注意してください。
以上がOracle SQLで複数の行を単一の行に集約するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。