Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Melakukan Carian Teks Penuh yang Cekap pada Jadual InnoDB Menggunakan MyISAM dan Prosedur Tersimpan?
Pencarian seperti Teks Penuh di InnoDB Menggunakan MyISAM dan Prosedur Tersimpan
Mencari cara yang cepat dan cekap untuk melaksanakan carian teks penuh pada jadual InnoDB boleh menjadi cabaran. Walaupun alat seperti Sphinx menyediakan penyelesaian, artikel ini meneroka pendekatan MySQL tulen menggunakan MyISAM dan prosedur tersimpan.
Cabaran
Pertanyaan ringkas yang mencari berbilang rentetan dalam barisan menggunakan pernyataan LIKE boleh menimbulkan masalah kerana prestasi dan pengehadannya yang perlahan.
SELECT ... WHERE row LIKE '%some%' OR row LIKE '%search%' OR row LIKE '%string%'
The Penyelesaian
Penyelesaian yang dicadangkan melibatkan penciptaan jadual teks penuh MyISAM yang mengindeks kembali ke dalam jadual InnoDB. Ini membenarkan untuk mengindeks lajur tertentu (cth., subjek) yang memerlukan carian.
Struktur Pangkalan Data
Jadual InnoDB ditakrifkan untuk data utama, seperti pengguna dan benang.
create table users (...) engine=innodb; create table forums (...) engine=innodb; create table threads ( ... subject varchar(255) not null, -- column we want to search ... ) engine=innodb;
Jadual teks penuh MyISAM (cth., threads_ft) menyediakan indeks carian.
create table threads_ft ( ... subject varchar(255) not null, fulltext (subject), -- fulltext index on subject ... ) engine=myisam;
Prosedur Tersimpan
Prosedur tersimpan (cth., ft_search_threads) menerima istilah carian sebagai input dan melakukan carian menggunakan indeks teks penuh MyISAM. Ia kemudiannya menggabungkan keputusan dengan jadual InnoDB untuk mendapatkan semula data yang diperlukan.
create procedure ft_search_threads ( in p_search varchar(255) ) begin ... select t.*, ... from threads_ft tft ... match(tft.subject) against (p_search in boolean mode) ... order by rank desc ... end;
Contoh Penggunaan
Prosedur yang disimpan boleh dipanggil daripada aplikasi PHP atau alat baris arahan:
call ft_search_threads('+innodb +clustered +index');
Contoh ini mengembalikan 100 hasil teratas daripada jadual urutan yang sepadan dengan carian istilah "innodb clustered index."
Dengan menggunakan pendekatan ini, anda boleh mencapai fungsi carian seperti teks penuh pada jadual InnoDB tanpa menjejaskan prestasi. Ia melibatkan mencipta jadual MyISAM khusus untuk mengindeks dan menulis prosedur tersimpan untuk melaksanakan carian dan pengambilan data.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melakukan Carian Teks Penuh yang Cekap pada Jadual InnoDB Menggunakan MyISAM dan Prosedur Tersimpan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!