索引失效场景或使用注意事项

a、索引无法存储null值,所以建议都给默认值

b、如果条件中有or,即使使用了索引条件也不起作用,所以尽量少用or

如果想使用or,又让索引生效,只能将or的每个列上加上索引

c、对于多列索引,不是使用其中的第一部分,则不会使用索引。

d、like查询以%开头(like '%XX'或者like '%XX%')

e、如果列类型是字符串,那一定要在条件中将数据使用引号引用起来,否则不使用索引

f、如果mysql估计使用全表扫描要比使用索引快,则不使用索引

g、索引的字段类型与传入参数不匹配,则索引失效

索引优化样例

1.使用索引时,关联表的条件字段中,字段长度和编码必须一致

a.fk_user_id = b.user_id ,fk_user_id 的编码是utf8 而 user_id 的编码方式是utf8mb4的,所以导致索引失效

2.尽量使用覆盖索引(只访问索引的查询(索引列包含查询列)),减少select *语句

SELECT name,age FROM employees WHERE name= 'jarye' AND age = 23 AND position ='ceo';----直接走索引

SELECT * FROM employees WHERE name= 'jarye' AND age = 23 AND position ='ceo';-----索引走了还会走二次查询

3.列类型是字符串,则必须使用''引号,否则不使用索引

SELECT * FROM employees WHERE name = 123;--索引会失效

SELECT * FROM employees WHERE name = '123';--索引生效

4.判断是否为空用is null,使用=null则不启用索引

select id from t where num is null;

注意: NULL 与任何值的直接比较都为 NULL。

1 ) NULL<>NULL 的返回结果是 NULL ,而不是 false 。

2 ) NULL=NULL 的返回结果是 NULL ,而不是 true 。

3 ) NULL<>1 的返回结果是 NULL ,而不是 true 。

5.应尽量避免在 where 子句中对”="左边进行函数、算数运算或表达式运算,这将导致引擎放弃使用索引而进行全表扫描。

select id from t where substring(name,1,3) = ’abc’ -–name 以 abc 开头的 id

select id from t where datediff(day,createdate,’2005-11-30′) = 0 -–‘2005-11-30’ –生成的 id

应改为:

select id from t where name like ‘abc%’

select id from t where createdate >= ‘2005-11-30’ and createdate < ‘2005-12-1’

6.在where子句中尽量避免使用!=或<>操作符,引擎会放弃使用索引而进行全表扫描。

SELECT * FROM employees WHERE name != 'jarye'

7.若中间索引列用到了范围(>、

SELECT * FROM employees WHERE name= 'jarye' AND age = 22 AND position ='ceo';----索引生效

SELECT * FROM employees WHERE name= 'jarye' AND age > 22 AND position ='ceo';----索引position无效

8.like前面有%会失效,如果字段长的话,可以考虑使用全文检索

Select * from dw_user where username like ‘%123%’——索引失效

Select * from dw_user where username like ‘%123’——索引失效

Select * from dw_user where username like ‘123%'——索引有效

9.在 where 子句中使用 or 来连接条件,必须全部索引存在才有效

如果一个字段有索引,一个字段没有索引,将导致引擎放弃使用索引而进行全表扫描,如:

select id from t where num=10 or Name = ‘admin’

可以这样查询:

select id from t where num = 10

union all

select id from t where Name = ‘admin’

10.有 order by 的场景,请注意利用索引的有序性【阿里巴巴JAVA开发手册】,参考order by中的单路和双路排序算法原理

order by 最后的字段是组合索引的一部分,并且放在索引组合顺序的最后,避免出现 file _ sort 的情况,影响查询性能。

正例: where a =? and b =? order by c; 索引: a _ b _ c

反例:索引中有范围查找,那么索引有序性无法利用,如: WHERE a >10 ORDER BY b; 索引a _ b 无法排序。

11.联合索引,第一条件必须使用,且尽可能按索引顺序执行

alter table dept add index my_ind (dname,loc);

select * from dept where dname=‘aaa’ and loc=‘aaa’———二个条件都使用了,索引生效

select * from dept where dname=‘aaa’——第一条件查询,使用索引

select * from dept where loc=‘aaa’——没有第一条件,不使用索引

建组合索引的时候,区分度最高的在最左边。

正例:如果 where a =? and b =? , a 列的几乎接近于唯一值,那么只需要单建 idx _ a 索引即可。

说明:存在非等号和等号混合判断条件时,在建索引时,请把等号条件的列前置。如: where a >? and b =? 那么即使 a 的区分度更高,也必须把 b 放在索引的最前列。

联合索引为什么需要遵循左前缀原则?

因为索引底层采用B+树叶子节点顺序排列,必须通过左前缀索引才能定位到具体的节点范围。

12. 在where子句中使用参数,也会导致全表扫描,可以使用强制索引

因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。如下面语句将进行全表扫描:

select id from t where num = @num

可以改为强制索引

select id from t with(index(索引名)) where num = @num

mysql 字符串索引 优化_MySQL性能优化之索引调优实战相关推荐

  1. mysql工具使用意义_MySQL性能分析、及调优工具使用详解

    本文汇总了MySQL DBA日常工作中用到的些工具,方便初学者,也便于自己查阅. 先介绍下基础设施(CPU.IO.网络等)检查的工具: vmstat.sar(sysstat工具包).mpstat.op ...

  2. mysql 查找相似数据_MySQL性能优化做得好的人,都懂的索引绝技

    一步一步推导出 MySQL索引的底层数据结构. MySQL作为互联网中非常热门的数据库,其底层的存储引擎和数据检索引擎的设计非常重要,尤其是 MySQL数据的存储形式以及索引的设计,决定了 MySQL ...

  3. mysql效率优化_MySQL性能优化的最佳12条经验

    数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我 们程序员需要去关注的事情.当我们去设计数据库表结构,对操作数据库时 ...

  4. mysql 阿里云 优化_MySQL性能优化速记

    总结自<MySQL 5.7从入门到精通(视频教学版)>刘增杰编著. 优化简介 MySQL数据库优化是多方面的,原则是减少系统的瓶颈,减少资源的占用,增加系统的反应速度. 在MySQL中,可 ...

  5. mysql sql 一部分记录_MySQL性能优化实践(很全面,值得收藏)

    一 题记 最近公司项目添加新功能,上线后发现有些功能的列表查询时间很久.原因是新功能用到旧功能的接口,而这些旧接口的 SQL 查询语句关联5,6张表且编写不够规范,导致 MySQL 在执行 SQL 语 ...

  6. 熟悉mysql数据库设计和性能优化_MySQL性能优化学习笔记-(1)数据库设计

    一.数据库设计 1.数据类型优缺点分析 数据类型的选择要遵循的总体原则 更小的通常更好 一般情况下,应该尽量选择使用可以正确存储数据的最小数据类型.更小的数据类型通常更快,因为它们站用更小的磁盘.内存 ...

  7. mysql not in优化_MySQL性能优化 — 实践篇2

    点赞再看,养成习惯,微信搜一搜[一角钱小助手]关注更多原创技术文章.本文 GitHub org_hejianhui/JavaStudy 已收录,有我的系列文章. 前言 MySQL索引底层数据结构与算法 ...

  8. Mysql删除语句优化_MySQL性能优化之常用SQL语句优化

    SQL性能优化的目标:至少要达到range级别,要求是ref级别,consts最高.[阿里巴巴JAVA开发手册] 说明: 1).consts单表中最多只有一个匹配行(主键/唯一索引),在优化阶段即可读 ...

  9. mysql 代码怎么优化_MySQL 性能优化的简略办法

    mysql 性能优化的简单办法 优化数据库最核心的实际上就是配置参数的调整.本文通过一个简单的参数调整,实现了对拥有一个几十万行表的 group by 优化的例子.通过这个简单的调整,数据库性能有了突 ...

最新文章

  1. VScode快速一键生成html、vue、jsx、ajax、sass、docker等代码片段
  2. FPGA逻辑设计回顾(3)多比特信号上升沿检测的设计方式与陷阱?
  3. 买卖股票的最佳时机|||
  4. 请你说明ConcurrentHashMap有什么优势以及1.7和1.8区别?
  5. c++文件中jni库找不到报红
  6. [AGC016B]Colorful Hats
  7. python fromarray_python --- 之pil image.fromarray
  8. 【Daily Scrum】
  9. js组件slotmachine_Vue.js 系列教程 2:组件,Props,Slots
  10. 美国通胀放缓幅度超预期 美元或面临进一步承压?
  11. TwinCAT3实现OPCUA通讯问题总结
  12. 【报错记录】解决Shell脚本报ambiguous redirect
  13. 抖音算法机制,抖音算法规则,抖音算法逻辑
  14. VSCode下载及各种实用插件安装教程
  15. java中定义变量名时大写_,【Java】变量命名规范
  16. GIC spec之ITS和LPI中断3
  17. python中int() 按照“四舍五入”的方式取整
  18. Gitlab 可以push但web端不显示文件
  19. Three.js用鼠标控制场景移动的代码
  20. JAVA基础-栈与堆,static、final修饰符、内部类和Java内存分配

热门文章

  1. HDU5730 FFT+CDQ分治
  2. (LeetCode 83)Remove Duplicates from Sorted Lists
  3. 搭建SpringMVC+Hibernate4+Spring3+Ajax+Maven项目(二)
  4. .NET:如何声明某个程序需要管理员权限
  5. Silverlight WCF 上传实现
  6. firewalld的防火墙
  7. easyGUI 用法介绍
  8. 从面试蚂蚁失败反思-缓存穿透技术
  9. 对springMVC的简单理解
  10. Windows8 64位运行Silverlight程序不能访问WCF的解决方案