關於Mysql模糊查詢的優化-全文檢索和Like的使用


表A:
CREATE TABLE `tableA` (
`id` int(11) NOT NULL auto_increment,
`content` varchar(256) default NULL,
PRIMARY KEY  (`id`),

如果我要在content中進行模糊查詢,那么使用like的話,肯定要這樣寫:
select * from tableA from content like "%xxx%"

這里有個問題,即使我為content加了index索引,那么在下面這兩種情況索引也是無效的
content like "%xxx" / like "%xxx%" 都不能使用索引

如果想索引作用只能使用content like "xxx%"

這時候就要使用全文索引來處理了
ALTER TABLE `tableA` ADD FULLTEXT `fidx_content` (`content`)

然后用以下方式查詢
SELECT * FROM `tableA`WHERE MATCH (content)AGAINST ('xxx')

EXPLAIN SELECT * FROM `wf_master`WHERE MATCH (cpr_no)AGAINST ('801876')
id  select_type  table       type      possible_keys  key         key_len  ref  rows  Extra
1   SIMPLE       wf_master  fulltext  fidx_cpr_no     fidx_cpr_no  0       1          Using where

需要注意的是全文檢索的對象是一個單詞,被檢索的詞需要用非文本隔開的

也就是說如果你在"abcd,efg,hijklmn"中檢索"hi",那么全文檢索也沒有用,如果你檢索efg,那么可以使用全文檢索

再有一點需要說明的是無論建立哪種索引,MYSQL內建函數: FIND_IN_SET, POSITION,LOCATE都不能使用索引


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM