Carian Cekap dengan MySQL CONCAT() Fungsi dalam Klausa WHERE
Satu operasi pangkalan data biasa sedang mencari data merentas berbilang lajur. Walau bagaimanapun, apabila mencari nama menggunakan medan nama pertama dan nama keluarga secara berasingan, mungkin terdapat had, seperti menangkap padanan yang tidak lengkap.
Untuk mengatasinya, fungsi MySQL CONCAT() boleh digunakan untuk menggabungkan lajur menjadi satu medan tunggal untuk carian. Ini menyediakan proses carian yang lebih diperkemas yang sepadan dengan kedua-dua nama pertama dan nama keluarga dengan tepat.
Menggunakan CONCAT() dalam Klausa WHERE
Untuk menggunakan CONCAT() dengan berkesan, hanya gabungkan lajur yang anda mahu cari:
select * from table where concat_ws(' ',first_name,last_name) like '%search_term%';
Pertanyaan ini akan mengembalikan semua baris yang sama ada nama_pertama, nama_akhir atau gabungannya sepadan dengan istilah_carian.
Contoh
Katakan kita mempunyai jadual dengan lajur nama_pertama dan nama_akhir serta ingin mencari "Larry Smith." Menggunakan CONCAT(), pertanyaannya ialah:
select * from table where concat_ws(' ',first_name,last_name) like '%Larry Smith%';
Pertanyaan ini akan mendapatkan semula baris yang dikehendaki, memberikan hasil carian yang lebih cekap dan tepat.
Pengoptimuman
Untuk prestasi optimum, anda dinasihatkan untuk memasukkan pernyataan CONCAT() sebagai segmen terakhir klausa WHERE anda, selepas mencari melalui medan lain yang berkaitan. Pendekatan ini telah terbukti lebih berkesan daripada meletakkan fungsi di tengah atau permulaan pertanyaan carian.
Atas ialah kandungan terperinci Bagaimanakah CONCAT() Boleh Meningkatkan Keupayaan Carian MySQL Anda untuk Padanan Nama Lengkap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!