SQL Server と Oracle で複数の行を単一のカンマ区切り列に連結するにはどうすればよいですか?
Jan 21, 2025 am 06:46 AM複数の行を単一のカンマ区切り列に結合する (SQL Server および Oracle)
このガイドでは、共有フィールド (TicketID
など) に基づいて複数の行を統合し、対応する値 (Person
など) を単一のカンマ区切り列 (People
など) に連結する方法を説明します。 SQL Server と Oracle の両方のソリューションを検討します。
SQL Server ソリューション
SQL Server は、効率的な文字列の連結と挿入のために STUFF
関数を利用します。 次の例はこれを示しています:
SELECT t.TicketID, STUFF( ISNULL(( SELECT ', ' + x.Person FROM @Tickets x WHERE x.TicketID = t.TicketID GROUP BY x.Person FOR XML PATH (''), TYPE ).value('.','VARCHAR(max)'), ''), 1, 2, '' ) [No Preceding Comma], ISNULL(( SELECT ', ' + x.Person FROM @Tickets x WHERE x.TicketID = t.TicketID GROUP BY x.Person FOR XML PATH (''), TYPE ).value('.','VARCHAR(max)'), '') [Preceding Comma If Not Empty] FROM @Tickets t GROUP BY t.TicketID
Oracle ソリューション
Oracle は、列値をカスタム区切り文字で連結するために特別に設計された LISTAGG
関数を提供します。 使用方法は次のとおりです:
SELECT TicketID, LISTAGG(Person, ',') WITHIN GROUP (ORDER BY Person) AS People FROM @Tickets GROUP BY TicketID
どちらの方法でも、連結された値をカンマで区切って、複数の行を単一の列に効果的にマージします。 関数の選択は、データベース システム (SQL Server または Oracle) によって異なります。
以上がSQL Server と Oracle で複数の行を単一のカンマ区切り列に連結するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

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

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

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

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

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

ホットトピック











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

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

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

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

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