カンマ区切りリストの生成: SQL アプローチ
データベース管理では、集約されたデータを効率的に表示することが重要です。 これには、多くの場合、カンマ区切りリストの作成が含まれます。 さまざまなデータベース システムに焦点を当て、単一の SQL クエリを使用してこれを実現する方法を検討してみましょう。 Applications
、Resources
、ApplicationsResources
テーブルを含むデータベース スキーマを使用します。目標は、各リソースの名前を、関連するアプリケーションのカンマ区切りリストと並べて表示することです。
最適化された単一クエリ ソリューション
複数のクエリに関連するパフォーマンスの問題を回避するには、単一のクエリを使用するのが最も効率的な方法です。 これには、関連するテーブルを結合し、適切な文字列集計関数を使用することが含まれます。 具体的な関数はデータベース システムによって異なります: GROUP_CONCAT
(MySQL)、STUFF
(SQL Server 2005 )、STRING_AGG
(SQL Server 2017 )、または Oracle の組み込み文字列集計メソッド。
データベース固有の実装
<code class="language-sql">SELECT r.name, GROUP_CONCAT(a.name SEPARATOR ',') AS application_list FROM RESOURCES r JOIN APPLICATIONSRESOURCES ar ON ar.resource_id = r.id JOIN APPLICATIONS a ON a.id = ar.app_id GROUP BY r.name;</code>
STUFF
関数の使用:<code class="language-sql">SELECT r.name, STUFF((SELECT ',' + a.name FROM APPLICATIONS a JOIN APPLICATIONRESOURCES ar ON ar.app_id = a.id WHERE ar.resource_id = r.id FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 1, '') AS application_list FROM RESOURCES r;</code>
STRING_AGG
関数の使用:<code class="language-sql">SELECT r.name, STRING_AGG(a.name, ',') AS application_list FROM RESOURCES r JOIN APPLICATIONSRESOURCES ar ON ar.resource_id = r.id JOIN APPLICATIONS a ON a.id = ar.app_id GROUP BY r.name;</code>
LISTAGG
または同様の文字列集約技術の使用が含まれます。 特定の構文については、Oracle のドキュメントを参照してください。概要
これらの単一クエリ ソリューションは、各リソースに関連するアプリケーションのカンマ区切りリストを生成する効率的な方法を提供します。 関数の選択は使用されているデータベース システムによって異なり、アプリケーションのユーザー インターフェイスに最適なパフォーマンスとデータ表示が保証されます。
以上がSQL で関連アプリケーションのカンマ区切りリストを効率的に作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。