Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mencipta Senarai Dipisahkan Koma dengan Cekap daripada Jadual Pangkalan Data Relasional menggunakan SQL?

Bagaimana untuk Mencipta Senarai Dipisahkan Koma dengan Cekap daripada Jadual Pangkalan Data Relasional menggunakan SQL?

Mary-Kate Olsen
Mary-Kate Olsenasal
2025-01-18 22:09:101037semak imbas

How to Efficiently Create Comma-Separated Lists from Relational Database Tables using SQL?

Mencipta Senarai Dipisahkan Koma Dengan Cekap Menggunakan SQL

Tugas pangkalan data selalunya memerlukan penyatuan medan data ke dalam senarai yang dipisahkan koma. SQL menawarkan penyelesaian yang cekap, menghapuskan keperluan untuk kod prosedur.

Contoh: Bayangkan tiga jadual: Applications (id, nama), Resources (id, nama) dan ApplicationsResources (id, app_id, resource_id). Objektifnya adalah untuk menjana laporan yang menunjukkan setiap nama sumber bersama senarai aplikasi yang dipisahkan koma.

Ini boleh dicapai menggunakan GROUP_CONCAT (MySQL dan beberapa versi SQL Server) atau STRING_AGG (SQL Server 2017 dan lebih baru). Fungsi ini menggabungkan nilai yang dikumpulkan mengikut lajur tertentu dengan cekap.

MySQL/Beberapa Versi Pelayan SQL:

<code class="language-sql">SELECT r.name, GROUP_CONCAT(a.name SEPARATOR ',') AS application_names
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 2017 dan Kemudian:

<code class="language-sql">SELECT r.name, STRING_AGG(a.name, ',') AS application_names
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 menawarkan beberapa kaedah pengagregatan rentetan, termasuk LISTAGG dan pakej DBMS_PCL_ROWPKT. Rujuk dokumentasi Oracle untuk mendapatkan arahan terperinci.

Pendekatan berasaskan SQL ini menawarkan kaedah yang diperkemas untuk menjana senarai dipisahkan koma, terus dalam pertanyaan pangkalan data anda, memperbaik persembahan data dalam aplikasi dan GUI.

Atas ialah kandungan terperinci Bagaimana untuk Mencipta Senarai Dipisahkan Koma dengan Cekap daripada Jadual Pangkalan Data Relasional menggunakan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn