Mengoptimumkan Carian MySQL Menggunakan "Suka" dan Kad Liar
Keadaan "suka" dengan aksara kad bebas boleh memberi kesan ketara kepada prestasi pertanyaan dalam MySQL apabila digunakan dengan kad bebas terkemuka. Sebabnya ialah kad bebas utama menghalang DBMS daripada menggunakan indeks, meninggalkan pertanyaan untuk melakukan carian linear melalui keseluruhan jadual.
Memandangkan pengehadan keadaan "suka" dengan kad bebas dan keteguhan nilai rentetan yang hendak dicari, pendekatan berbeza diperlukan untuk meningkatkan prestasi. Pendekatan ini melibatkan penciptaan jadual akhiran untuk setiap perkataan yang hendak dicari.
Dengan menyimpan setiap kemungkinan akhiran setiap perkataan, pertanyaan menggunakan keadaan "suka" dengan hanya kad bebas mengekori kini boleh memanfaatkan indeks. Keadaan "suka" tidak lagi akan dihalang oleh kad bebas terkemuka, membolehkan carian cekap menggunakan pertanyaan julat pada indeks.
Kos storan yang dikaitkan dengan pendekatan ini adalah pertukaran. Walaupun ia menghapuskan overhed storan kad bebas utama dalam keadaan "suka", ia memperkenalkan keperluan storan tambahan untuk jadual akhiran. Ruang storan yang diperlukan meningkat secara mendadak dengan peningkatan panjang perkataan.
Pertimbangan pelaksanaan termasuk menentukan strategi pemisahan perkataan yang sesuai (cth., mengendalikan tanda sempang), mengimbangi overhed storan dengan kecekapan pertanyaan dan meneroka kaedah storan alternatif untuk tatasusunan akhiran untuk meminimumkan kos penyimpanan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengoptimumkan Carian MySQL Menggunakan 'LIKE' dengan Wildcards?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!