Corak Pangkalan Data: UNION ALL untuk Carian Progresif
Apabila mencari data dalam pangkalan data, kadangkala perlu melaraskan kriteria carian secara berperingkat sehingga keputusan ditemui. Ini biasanya dikenali sebagai "carian progresif."
Pertimbangkan senario berikut: anda ingin mencari satu baris dalam jadual imej berdasarkan nama dan ID kumpulan. Jika itu tidak menghasilkan hasil, anda ingin mencari nama yang sama tanpa ID kumpulan dan jika itu masih tidak menghasilkan hasil, anda mahu mencari ID kumpulan tanpa nama.
Pertanyaan Carian Progresif
Pertanyaan SQL yang paling berkesan untuk carian progresif ialah:
SELECT * FROM image WHERE name = 'text' AND group_id = 10 UNION ALL SELECT * FROM image WHERE name = 'text' UNION ALL SELECT * FROM image WHERE group_id = 10 LIMIT 1;
Penjelasan
Pengoptimuman
Untuk memastikan prestasi optimum, adalah penting untuk mencipta indeks berikut pada jadual imej:
CREATE INDEX image_name_grp_idx ON image (name, group_id); CREATE INDEX image_grp_idx ON image (group_id);
Skalabiliti
Pertanyaan carian progresif ini boleh berskala dan boleh disesuaikan untuk mencari berbilang parameter dengan ketepatan yang berbeza-beza. Cuma tambah penyataan SELECT tambahan untuk setiap parameter dan laraskan kriteria dengan sewajarnya.
Kesimpulan
Pertanyaan UNION ALL yang dibentangkan di sini ialah penyelesaian serba boleh untuk carian progresif. Ia membolehkan anda mencari data secara berperingkat sambil memastikan kedua-dua kelajuan dan ketepatan. Dengan mengikuti garis panduan ini, anda boleh melaksanakan carian progresif dengan berkesan dalam aplikasi pangkalan data anda.
Atas ialah kandungan terperinci Bagaimanakah UNION ALL Boleh Melaksanakan Carian Pangkalan Data Progresif?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!