Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mencipta Senarai Dipisahkan Koma dengan Cekap daripada Jadual Pangkalan Data Relasional 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!