Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Melakukan Carian Teks Penuh yang Cekap pada Jadual InnoDB Menggunakan MyISAM dan Prosedur Tersimpan?

Bagaimanakah Saya Boleh Melakukan Carian Teks Penuh yang Cekap pada Jadual InnoDB Menggunakan MyISAM dan Prosedur Tersimpan?

Linda Hamilton
Linda Hamiltonasal
2024-12-16 12:14:15825semak imbas

How Can I Perform Efficient Full-Text Search on InnoDB Tables Using MyISAM and Stored Procedures?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn