关于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都不能使用索引
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都不能使用索引
相关文章推荐
- 关于Mysql模糊查询的优化-全文检索和Like的使用
- MySql模糊查询like通配符使用详细介绍
- MySql模糊查询like通配符使用详细介绍 分类: database 测试 2014-02-12 10:19 6829人阅读 评论(1) 收藏
- MySql模糊查询like通配符使用详细介绍
- MySql模糊查询like通配符使用详细介绍
- MySql like模糊查询通配符使用详细介绍
- 关于mysql 使用or连接索引失效引起的慢查询优化的初步实践
- MySql like模糊查询通配符使用详细介绍
- mysql中like模糊查询优化
- Lucene.Net, SQL Server 2008全文检索, Like模糊查询的一点心得
- Lucene.Net, SQL Server 2008全文检索, Like模糊查询的一点心得(转)
- Mysql中使用like进行模糊查询反斜线等符号转义处理
- MySql模糊查询like通配符使用详细介绍
- java mysql prepareStatement模糊查询like使用注意
- mysql使用参数化查询,like模糊查询,应如何拼接字符串
- MySql模糊查询like通配符使用详细介绍
- MySql模糊查询like通配符使用详细介绍
- MySql like模糊查询通配符使用详细介绍
- MySql模糊查询like通配符与使用正则查询详细介绍
- MySql模糊查询like通配符使用详细介绍