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

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

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

表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都不能使用索引

总结

以上是内存溢出为你收集整理的关于Mysql模糊查询的优化-全文检索和Like的使用全部内容,希望文章能够帮你解决关于Mysql模糊查询的优化-全文检索和Like的使用所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1151523.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存