ホームページ > データベース > mysql チュートリアル > SQL で関連アプリケーションのカンマ区切りリストを効率的に作成するにはどうすればよいですか?

SQL で関連アプリケーションのカンマ区切りリストを効率的に作成するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2025-01-18 22:12:13
オリジナル
758 人が閲覧しました

How to Efficiently Create Comma-Separated Lists of Associated Applications in SQL?

カンマ区切りリストの生成: SQL アプローチ

データベース管理では、集約されたデータを効率的に表示することが重要です。 これには、多くの場合、カンマ区切りリストの作成が含まれます。 さまざまなデータベース システムに焦点を当て、単一の SQL クエリを使用してこれを実現する方法を検討してみましょう。 ApplicationsResourcesApplicationsResources テーブルを含むデータベース スキーマを使用します。目標は、各リソースの名前を、関連するアプリケーションのカンマ区切りリストと並べて表示することです。

最適化された単一クエリ ソリューション

複数のクエリに関連するパフォーマンスの問題を回避するには、単一のクエリを使用するのが最も効率的な方法です。 これには、関連するテーブルを結合し、適切な文字列集計関数を使用することが含まれます。 具体的な関数はデータベース システムによって異なります: GROUP_CONCAT (MySQL)、STUFF (SQL Server 2005 )、STRING_AGG (SQL Server 2017 )、または Oracle の組み込み文字列集計メソッド。

データベース固有の実装

  • MySQL:
<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>
ログイン後にコピー
  • SQL Server (2005 以降): 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>
ログイン後にコピー
  • SQL Server (2017 以降): より簡潔な 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>
ログイン後にコピー
  • Oracle: Oracle のアプローチには、LISTAGG または同様の文字列集約技術の使用が含まれます。 特定の構文については、Oracle のドキュメントを参照してください。

概要

これらの単一クエリ ソリューションは、各リソースに関連するアプリケーションのカンマ区切りリストを生成する効率的な方法を提供します。 関数の選択は使用されているデータベース システムによって異なり、アプリケーションのユーザー インターフェイスに最適なパフォーマンスとデータ表示が保証されます。

以上がSQL で関連アプリケーションのカンマ区切りリストを効率的に作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート