1、常见用法:

(1)搭配%使用

%代表一个或多个字符的通配符,譬如查询字段name中以大开头的数据:

(2)搭配_使用

_代表仅仅一个字符的通配符,把上面那条查询语句中的%改为_,会发现只能查询出下面一条数据:

2、使用like模糊查询会导致索引失效,在数据量大的时候会有性能问题

(1)尽量少以%或者_开头进行模糊查询

通过explain执行计划,我们发现,使用like模糊查询时,如果不以%和_开头查询的话,索引还是有效的

以%或者_开头查询,索引失效

(2)使用覆盖索引

当查询的的条件和查询的结果都是索引中的字段的时候,这个索引我们可以称之为覆盖索引,这个时候,使用like模糊查询索引是有效的

InnoDB中主键可以不添加进索引中

注意:使用覆盖索引,对于字段的长度是由要求限制的,一般超过长度,索引也会失效

这里如果我查询中带有descripition字段,则覆盖索引也会失效(我这里的数据库经过测试最多只支持255长度的字段)

(3)使用全文索引

给字段建立Full Text索引,然后使用match(...) against(...)进行检索
 

注意:这种全文索引方式只对英文单词起作用,对于中文汉字支持不够友好,并且分词有时候不是很准确,除非有明显的分隔符,需要额外去mysql的配置文件做一些配置修改,让它额外支持中文

(4)使用一些额外的全文搜索引擎来解决

Lucene,solr,elasticsearch等等

基本原理是:把mysql配置文件中的ft_min_word_len=3改为1。(没有这项就直接添加),然后新建一个字段来保持分词结果,给这个字段建立全文索引。然后实现一个分词模块,把词语“大家好”拆分为“大 大家 大家好 家 家好 好”。然后用match .. against 来代替like %%,查询出来的结果跟like的结果基本相同(如果分词合理的话),但是效率比like高至少10倍以上。

【性能】模糊查询性能提升相关推荐

  1. MySQL模糊查询性能优化

    一.背景 我们经常在数据库中使用 LIKE 操作符来完成对数据的模糊搜索,LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式. 如果需要查找客户表中所有姓氏是"孙"的数据 ...

  2. 中文模糊查询性能优化 by PostgreSQL trgm

    前模糊,后模糊,前后模糊,正则匹配都属于文本搜索领域常见的需求. PostgreSQL在文本搜索领域除了全文检索,还有trgm是一般数据库没有的,甚至可能很多人没有听说过. 对于前模糊和后模糊,PG则 ...

  3. Oracle 模糊查询性能优化

    问题:使用like模糊查询,性能不是很好,寻求更高效的模糊查询的方法 解决:使用oracle自带的instr()函数解决 参考:https://blog.csdn.net/u010028869/art ...

  4. ORACLE中Like与Instr模糊查询性能大比拼

    instr(title,'手册')>0  相当于  title like '%手册%' instr(title,'手册')=1  相当于  title like '手册%' instr(titl ...

  5. oracle怎么优化模糊查询性能,ORACLE模糊查询优化浅谈

    模糊查询是数据库查询中经常用到的,一般常用的格式如下: (1)字段  like '%关键字%'   字段包含"关键字"的记录   即使在目标字段建立索引也不会走索引,速度最慢   ...

  6. mysql 主键查询性能_MySQL查询性能优化(精)

    MySQL查询性能优化 MySQL查询性能的优化涉及多个方面,其中包括库表结构.建立合理的索引.设计合理的查询.库表结构包括如何设计表之间的关联.表字段的数据类型等.这需要依据具体的场景进行设计.如下 ...

  7. postgresql分妺_中文模糊查询性能优化 by PostgreSQL trgm-阿里云开发者社区

    前模糊,后模糊,前后模糊,正则匹配都属于文本搜索领域常见的需求. PostgreSQL在文本搜索领域除了全文检索,还有trgm是一般数据库没有的,甚至可能很多人没有听说过. 对于前模糊和后模糊,PG则 ...

  8. 高性能MySQL学习——提高查询性能

    高性能MySQL学习--提高查询性能 提高查询性能 MySQL 查询优化器 MySQL 执行计划分析"三步曲" MySQL 执行计划查询分析 如何优化 SQL MySQL 自身优化 ...

  9. Greenplum 模糊查询 实践

    标签 PostgreSQL , Greenplum , orafunc , 阿里云HybridDB for PostgreSQL , reverse , like , 模糊查询 背景 文本搜索的需求分 ...

最新文章

  1. 修改mysql   默认字符集 , 默认引擎
  2. jsp 中forward 和 Redirect 的用法区别
  3. hudo as3 网络通信框架
  4. nexus 6p Android SDK,Flutter没有检测到Android SDK
  5. jQuery经典案例【倒计时】
  6. 学习Spring Boot:(二十二)使用 AOP
  7. 人工智能 对比试验_人工智能与药物研发
  8. SpringBoot项目中遇到的BUG
  9. nohup命令导致nohup.out文件过大处理办法
  10. AMP (LAMP/WAMP)
  11. java虚拟机(八)--java性能监控与故障处理工具
  12. centos6.5搭建lnmp过程
  13. 高质量响应式的 HTML/CSS 网站模板
  14. Kruscal算法---最小生成树
  15. Excel 2013 查找和替换单元格内换行回车
  16. 计算机房面积设置气消条件,广东省《建筑防烟排烟系统技术标准》问题释疑
  17. Linux添加中文字体
  18. 基于PMOS的过压保护(OVP)电路仿真
  19. 卷积神经网络CNN-全连接层
  20. android打开wav格式,在Android中使用AudioTrack播放WAV文件

热门文章

  1. rust 睡袋怎么用_买过50+件睡袋的妈妈推荐这几款!
  2. linux编程能否用于windows,使R包在Windows和Linux中都可以工作
  3. 解决MyBatis的报错 There is no getter for property named ‘*‘ in ‘class java.lang.String‘
  4. mysql 临时文件目录_MySQL数据库的临时文件究竟储存在哪里
  5. 符号未定义Java_Java ODBC数据源(未定义符号:SQLAllocEnv)
  6. 固态硬盘量产工具_机械硬盘Q1出货量大降,电脑硬盘榜单出炉
  7. android camera 实时滤镜,【Camera】Android平台Camera实时滤镜实现方法
  8. 五、Hive数据类型和简单使用
  9. 四、从Excel开始,学习Excel的快捷键
  10. 送书福利 | 哈工大SCIR倾力打造NLP新书,详解预训练语言模型