zoukankan      html  css  js  c++  java
  • 关于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都不能使用索引

  • 相关阅读:
    字符串匹配之朴素匹配
    XSS的攻击原理
    使用metasploit收集邮箱
    C++实现折半插入排序
    C++插入排序实现
    Java中的NIO
    Hashtable和HashMap区别(面试)
    面向对象:封装(一):构造函数;类的主方法;权限修饰符;对象的创建
    switch多分支语句
    递归和字母数字生成随机数
  • 原文地址:https://www.cnblogs.com/qichao123/p/7802757.html
Copyright © 2011-2022 走看看