Oracle の LISTAGG のように SQL Server で文字列を集計するにはどうすればよいですか?
Jan 22, 2025 pm 01:01 PMSQL Server のリスト集計
SQL Server は、複数の行の値を単一のカンマ区切り文字列に連結する機能など、データ集約のための強力な関数セットを提供します。この集計方法を習得することは、さまざまなデータ集計やプレゼンテーションのタスクにとって重要です。
SQL Server で Oracle の LISTAGG 関数と同じ機能を実現するには、STRING_AGG 関数を使用できます。 SQL Server 2017 で導入されたこの関数を使用すると、グループ内の文字列を連結できます。
例
次のデータセットについて考えてみましょう:
字段 A | 字段 B |
---|---|
1 | A |
1 | B |
2 | A |
クエリ:
SELECT FieldA, STRING_AGG(FieldB, ',') WITHIN GROUP (ORDER BY FieldB) AS FieldBs FROM TableName GROUP BY FieldA ORDER BY FieldA;
結果:
字段 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 サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

共通の脆弱性(SQLインジェクション、ブルートフォース攻撃)に対してMySQLを保護するにはどうすればよいですか?

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
