


Bagaimana untuk Mencipta Senarai Dipisahkan Koma dengan Cekap daripada Jadual Pangkalan Data Relasional menggunakan SQL?
Jan 18, 2025 pm 10:09 PMMencipta 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:
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;
SQL Server 2017 dan Kemudian:
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;
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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Bagaimanakah saya menjamin MySQL terhadap kelemahan biasa (suntikan SQL, serangan kekerasan)?

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?
