MySQL ialah salah satu sistem pangkalan data hubungan yang paling biasa digunakan dalam pembangunan web. Dalam MySQL, kita boleh menggunakan pernyataan IN untuk menanyakan data dalam koleksi. Pernyataan IN sesuai untuk menentukan berbilang nilai dalam koleksi tanpa perlu menulis berbilang klausa ATAU.
Sebagai contoh, jika kita ingin mencari semua rekod dengan ID 1, 2, 3 dan 4 dalam set rekod, kita boleh menggunakan pernyataan pertanyaan berikut:
PILIH * DARI table_name DI MANA ID IN (1, 2,3,4);
Walau bagaimanapun, susunan pernyataan IN akan menjejaskan kecekapan pertanyaan. Oleh itu, apabila menggunakan pernyataan IN untuk membuat pertanyaan pengumpulan data, mengoptimumkan susunan pernyataan pertanyaan boleh meningkatkan kecekapan pertanyaan.
Dalam MySQL, susunan pemprosesan dalaman pernyataan IN adalah dari kiri ke kanan. Ini bermakna MySQL akan terlebih dahulu menyemak nilai paling kiri dalam keadaan pertanyaan, dan kemudian menyemak nilai di sebelah kanan satu demi satu.
Sebagai contoh, untuk pernyataan pertanyaan berikut:
PILIH * DARI nama_jadual DI MANA A DALAM (1,2) DAN B DALAM (3,4);
MySQL Pertama akan menyemak Jika lajur A mengandungi 1, kemudian semak untuk 2. Jika lajur A mengandungi nilai ini, MySQL akan terus menyemak sama ada lajur B mengandungi 3 dan 4.
Oleh itu, jika set syarat pertanyaan mengandungi nilai yang lebih sedikit, pertanyaan akan menjadi lebih cekap. Dalam contoh di atas, jika lajur A mengandungi hanya beberapa rekod, ia akan menjadi lebih pantas apabila membuat pertanyaan kerana MySQL tidak perlu menyemak banyak rekod.
Untuk mengoptimumkan lagi kecekapan pertanyaan pernyataan IN, anda boleh menggunakan subquery (Subquery). Subkueri boleh menggunakan hasil pertanyaan lain sebagai syarat dalam pertanyaan. Berikut ialah contoh menggunakan subquery:
SELECT * FROM table_name WHERE A IN (SELECT A FROM table_name WHERE B=3);
Dalam pernyataan pertanyaan di atas, subquery SELECT A FROM table_name WHERE B=3
Mengembalikan set hasil yang mengandungi nilai B=3 dalam lajur A. Pertanyaan utama akan menggunakan set hasil subkueri ini sebagai syarat pertanyaan pernyataan IN. Kaedah ini mempunyai kecekapan pertanyaan yang lebih tinggi kerana MySQL melaksanakan subkueri terlebih dahulu dan kemudian menggunakan hasil subkueri untuk pertanyaan utama. Ini bermakna MySQL hanya menyemak rekod yang perlu disemak, sekali gus mengurangkan masa pertanyaan.
Selain itu, anda boleh menggunakan pernyataan EXISTS untuk mengesahkan sama ada hasil pertanyaan wujud. Contohnya:
PILIH DARI nama_jadual t1 DI MANA WUJUD (PILIH DARI nama_jadual t2 DI MANA t1.A=t2.A DAN t2.B=3);
Di atas pertanyaan Pernyataan itu akan mengembalikan set rekod unik yang mengandungi 3 dalam lajur A nama_jadual jadual.
Ringkasnya, susunan pertanyaan IN boleh menjejaskan kecekapan pertanyaan, dan kecekapan pertanyaan boleh dipertingkatkan dengan mengoptimumkan susunan pernyataan pertanyaan Penggunaan subkueri dan pernyataan EXISTS ialah istilah untuk pertanyaan yang cekap. Dalam MySQL, kita mesti menggunakan penyataan dan teknik pertanyaan ini secara munasabah untuk meningkatkan kecekapan pertanyaan.
Atas ialah kandungan terperinci mysql dalam susunan pertanyaan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!