首頁 >資料庫 >mysql教程 >如何使用MyISAM和預存程序對InnoDB表進行高效率的全文搜尋?

如何使用MyISAM和預存程序對InnoDB表進行高效率的全文搜尋?

Linda Hamilton
Linda Hamilton原創
2024-12-16 12:14:15824瀏覽

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

使用MyISAM 和預存程序在InnoDB 上進行全文搜尋

找到一種快速有效的方法來對InnoDB 表執行全文搜尋可以是一個挑戰。雖然 Sphinx 等工具提供了解決方案,但本文探討了使用 MyISAM 和預存程序的純 MySQL 方法。

挑戰

一個在以下位置搜尋多個字串的簡單查詢由於效能緩慢和限制,使用 LIKE 語句的行可能會出現問題。

SELECT ... WHERE row LIKE '%some%' OR row LIKE '%search%' OR  row LIKE '%string%'

解決方案

建議的解決方案涉及建立一個 MyISAM 全文表,該表將索引回 InnoDB 表。這允許對需要搜尋的特定列(例如主題)建立索引。

資料庫結構

InnoDB 表是為主要資料定義的,例如使用者和執行緒。

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;

MyISAM 全文表(例如,threads_ft)提供搜尋index.

create table threads_ft (
...
subject varchar(255) not null,
fulltext (subject), -- fulltext index on subject
...
)
engine=myisam;

預存程序

預存程序
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;

預存程序(例如,ft_search )接受搜尋項目作為輸入,並使用MyISAM 全文索引執行搜尋。然後它將結果與 InnoDB 表連接起來以檢索必要的資料。

範例用法
call ft_search_threads('+innodb +clustered +index');

可以從PHP 應用程式或命令列工具:

此範例返回執行緒表中與此搜尋匹配的前100 個結果術語“innodb 聚集索引”。 透過利用此方法,您可以在 InnoDB 表上實現類似全文的搜尋功能,而不會影響效能。它涉及創建一個專用的 MyISAM 表用於索引和編寫一個預存程序來執行搜尋和資料檢索。

以上是如何使用MyISAM和預存程序對InnoDB表進行高效率的全文搜尋?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn