您的位置:首页 > 数据库 > MySQL

关于Mysql模糊查询的优化-全文检索和Like的使用

2015-01-09 09:34 741 查看
表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都不能使用索引
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: