ホームページ >データベース >mysql チュートリアル >Oracle の LISTAGG のように SQL Server で文字列を集計するにはどうすればよいですか?

Oracle の LISTAGG のように SQL Server で文字列を集計するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-22 13:01:15193ブラウズ

How Can I Aggregate Strings in SQL Server Like Oracle's LISTAGG?

SQL Server のリスト集計

SQL Server は、複数の行の値を単一のカンマ区切り文字列に連結する機能など、データ集約のための強力な関数セットを提供します。この集計方法を習得することは、さまざまなデータ集計やプレゼンテーションのタスクにとって重要です。

SQL Server で Oracle の LISTAGG 関数と同じ機能を実現するには、STRING_AGG 関数を使用できます。 SQL Server 2017 で導入されたこの関数を使用すると、グループ内の文字列を連結できます。

次のデータセットについて考えてみましょう:

字段 A 字段 B
1 A
1 B
2 A

クエリ:

<code class="language-sql">SELECT FieldA,
       STRING_AGG(FieldB, ',') WITHIN GROUP (ORDER BY FieldB) AS FieldBs
FROM TableName
GROUP BY FieldA
ORDER BY FieldA;</code>

結果:

字段 A FieldBs
1 A, B
2 A

WITHIN GROUP 句を指定した STRING_AGG 関数により、FieldA によってグループ化された各グループ内で値が確実に連結されます。集計内の ORDER BY 句は、値をリストする順序を指定します。

2017 より前のバージョンの SQL Server では、CTE (共通テーブル式) と STUFF 関数を組み合わせて使用​​して、同じ結果を得ることができます。ただし、簡素化と新しいバージョンとの互換性のために、STRING_AGG 関数が推奨されるソリューションです。

以上がOracle の LISTAGG のように SQL Server で文字列を集計するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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