【性能】模糊查询性能提升
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倍以上。
【性能】模糊查询性能提升相关推荐
- MySQL模糊查询性能优化
一.背景 我们经常在数据库中使用 LIKE 操作符来完成对数据的模糊搜索,LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式. 如果需要查找客户表中所有姓氏是"孙"的数据 ...
- 中文模糊查询性能优化 by PostgreSQL trgm
前模糊,后模糊,前后模糊,正则匹配都属于文本搜索领域常见的需求. PostgreSQL在文本搜索领域除了全文检索,还有trgm是一般数据库没有的,甚至可能很多人没有听说过. 对于前模糊和后模糊,PG则 ...
- Oracle 模糊查询性能优化
问题:使用like模糊查询,性能不是很好,寻求更高效的模糊查询的方法 解决:使用oracle自带的instr()函数解决 参考:https://blog.csdn.net/u010028869/art ...
- ORACLE中Like与Instr模糊查询性能大比拼
instr(title,'手册')>0 相当于 title like '%手册%' instr(title,'手册')=1 相当于 title like '手册%' instr(titl ...
- oracle怎么优化模糊查询性能,ORACLE模糊查询优化浅谈
模糊查询是数据库查询中经常用到的,一般常用的格式如下: (1)字段 like '%关键字%' 字段包含"关键字"的记录 即使在目标字段建立索引也不会走索引,速度最慢 ...
- mysql 主键查询性能_MySQL查询性能优化(精)
MySQL查询性能优化 MySQL查询性能的优化涉及多个方面,其中包括库表结构.建立合理的索引.设计合理的查询.库表结构包括如何设计表之间的关联.表字段的数据类型等.这需要依据具体的场景进行设计.如下 ...
- postgresql分妺_中文模糊查询性能优化 by PostgreSQL trgm-阿里云开发者社区
前模糊,后模糊,前后模糊,正则匹配都属于文本搜索领域常见的需求. PostgreSQL在文本搜索领域除了全文检索,还有trgm是一般数据库没有的,甚至可能很多人没有听说过. 对于前模糊和后模糊,PG则 ...
- 高性能MySQL学习——提高查询性能
高性能MySQL学习--提高查询性能 提高查询性能 MySQL 查询优化器 MySQL 执行计划分析"三步曲" MySQL 执行计划查询分析 如何优化 SQL MySQL 自身优化 ...
- Greenplum 模糊查询 实践
标签 PostgreSQL , Greenplum , orafunc , 阿里云HybridDB for PostgreSQL , reverse , like , 模糊查询 背景 文本搜索的需求分 ...
最新文章
- 修改mysql 默认字符集 , 默认引擎
- jsp 中forward 和 Redirect 的用法区别
- hudo as3 网络通信框架
- nexus 6p Android SDK,Flutter没有检测到Android SDK
- jQuery经典案例【倒计时】
- 学习Spring Boot:(二十二)使用 AOP
- 人工智能 对比试验_人工智能与药物研发
- SpringBoot项目中遇到的BUG
- nohup命令导致nohup.out文件过大处理办法
- AMP (LAMP/WAMP)
- java虚拟机(八)--java性能监控与故障处理工具
- centos6.5搭建lnmp过程
- 高质量响应式的 HTML/CSS 网站模板
- Kruscal算法---最小生成树
- Excel 2013 查找和替换单元格内换行回车
- 计算机房面积设置气消条件,广东省《建筑防烟排烟系统技术标准》问题释疑
- Linux添加中文字体
- 基于PMOS的过压保护(OVP)电路仿真
- 卷积神经网络CNN-全连接层
- android打开wav格式,在Android中使用AudioTrack播放WAV文件
热门文章
- rust 睡袋怎么用_买过50+件睡袋的妈妈推荐这几款!
- linux编程能否用于windows,使R包在Windows和Linux中都可以工作
- 解决MyBatis的报错 There is no getter for property named ‘*‘ in ‘class java.lang.String‘
- mysql 临时文件目录_MySQL数据库的临时文件究竟储存在哪里
- 符号未定义Java_Java ODBC数据源(未定义符号:SQLAllocEnv)
- 固态硬盘量产工具_机械硬盘Q1出货量大降,电脑硬盘榜单出炉
- android camera 实时滤镜,【Camera】Android平台Camera实时滤镜实现方法
- 五、Hive数据类型和简单使用
- 四、从Excel开始,学习Excel的快捷键
- 送书福利 | 哈工大SCIR倾力打造NLP新书,详解预训练语言模型