我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL索引优化

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL索引优化

MySQL索引优化

一、单表

创建索引之前:type=ALL全表扫描,Extra里面的Using filesort(文件内部排序)

根据where后面的条件创建CREATE INDEX idx_article_ccv ON article(category_id,comments,views);

   可以看出type由ALL变成了range,但是Extra里面的Using filesort(文件内部排序)未解决

   此时删除索引:DROP INDEX idx_article_ccv ON article;

   重新建立CREATE INDEX idx_article_ccv ON article(category_id,views);

 

此时完美解决!!

二、双表

 创建索引之前:type=ALL全表扫描

 此时有两个表,里面都有字段card,但是现在不知道应该建左表class还是右表book,所以可以先建右表book,查看之后再进行优化

ALTER TABLE book ADD index  Y("card");

此时可以明显看到book表得到优化type=ref,但是class表未得到改变,于是删除索引DROP INDEX Y ON book;

现在加左表class: ALTER TABLE class ADD INDEX Y ("card");

此时看到class表的type=index,建立在右表type=ref,因为ref>index,rows=40>前者的21,所以权衡之间,得到:

  左右连接时,左连接建右表索引,右连接建左边索引,因为这是由于左右连接特性决定的,左连接左表一定都有,右表成了关键点,所以右表一定要建立索引,右连接反之。

 三、三表

  创建索引之前:type=ALL全表扫描,rows=60

 

  从上面两表或查询中总结出左连接建右表,那么这里给phone表和book表创建索引

  创建好索引后查看结论

 

此时看到后两行的type都为ref,中rows=22,优化的很好,因此索引最好建立在经常查询的字段中

四、索引失效

最佳左前缀法则:如果索引了多列,指的是查询从索引的最左抢前列开始并且不跳过索引中的列

问题:如何解决like %字符串%索引失效

  1、百分号只写右边aa%不失效

  2、使用覆盖索引【何为覆盖索引见我的上一篇文章MySQL的explain中有解释】

小结:

优化口诀:

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL索引优化

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL索引优化

一、单表创建索引之前:type=ALL全表扫描,Extra里面的Using filesort(文件内部排序)根据where后面的条件创建:CREATE INDEX idx_article_ccv ON article(category_id,comments,
MySQL索引优化
2019-01-06

MySQL索引优化EXPLAIN

日常在CURD的过程中,都避免不了跟数据库打交道,大多数业务都离不开数据库表的设计和SQL的编写,那如何让你编写的SQL语句性能更优呢? 先来整体看下MySQL逻辑架构图: MySQL整体逻辑架构图可以分为Server和存储引擎层。 Server层: Ser
MySQL索引优化EXPLAIN
2015-10-24

MySQL优化之索引

SQL为什么需要优化?对于初学者来说,能够写出实现功能的SQL语句而不出错,查询出所需要的结果,就已经能够满足日常使用了。但在某些场景,对性能的要求比较高,因此,要求SQL的执行响应速度快,就需要对SQL进行一定程度的优化。在实际应用场景中,MySQL经常会存
MySQL优化之索引
2021-02-14

MySQL优化(3):索引

MySQL优化中,最重要的优化手段就是索引,也是最常用的优化手段 索引简介:索引:关键字与数据位置之间的映射关系关键字:从数据中提取,用于标识,检索数据的特定内容目的:加快检索 索引检索为什么快:(1)关键字相对于数据本身,量较小(2)关键字都是排序好的 My
MySQL优化(3):索引
2014-05-17

MySQL索引优化深入

创建 test 测试表CREATE TABLE `test` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `c1` varchar(10) DEFAULT NULL,  `c2` varchar(10) DEFAULT 
MySQL索引优化深入
2016-11-27

MySQL 索引优化案例

目录数据准备联合索引的首字段用范围查询强制走索引覆盖索引优化in和or什么时候会走索引like xx% 一般都会走索引,和数据量无关索引下推为什么范围查找没有用索引下推优化?如何选择索引Trace 工具深入优化order by 和 grou
2022-08-19

MySQL如何优化索引

1. MySQL如何使用索引 索引用于快速查找具有特定列值的行。如果没有索引,MySQL必须从第一行开始,然后遍历整个表以找到相关的行。表越大,花费越多。如果表中有相关列的索引,MySQL可以快速确定要在数据文件中间查找的位置,而不必查看
2022-05-27

mysql索引怎么优化

1. 使用合适的数据类型:选择合适的数据类型可以减小索引的大小,提高查询速度。例如,使用INT类型代替VARCHAR类型存储数字字段。2. 选择合适的索引列:在创建索引时,选择最常被查询的列作为索引列,可以提高查询速度。避免创建过多的索引,
mysql索引怎么优化
2024-02-29

MySQL索引优化分享

2,explain的作⽤ 查看表的读取顺序,读取操作类型,有哪些索引可用,表之间关联,每张表中有哪些索引被优化器执⾏3,索引命中策略略分析    最左匹配原则 在索引字段上加入函数(不匹配索引)    is null/is not null/not in(不匹
MySQL索引优化分享
2016-09-28

SQL索引(索引优化)

#1.最左前缀匹配原则,非常重要的原则, create index ix_name_email on s1(name,email,) - 最左前缀匹配:必须按照从左到右的顺序匹配 select * from s1 where name="egon"; #可以
SQL索引(索引优化)
2021-11-01

MySQL索引优化Linux案例

在MySQL中,索引是一种优化数据库表查询的技朮。通过为查询字段创建索引,可以大大提高数据检索的速度。下面是一个在Linux环境下优化MySQL索引的案例:登录MySQL数据库:mysql -u root -p查看当前数据库中的表和索引:S
MySQL索引优化Linux案例
2024-08-16

MySQL优化之索引解析

索引的本质MySQL索引或者说其他关系型数据库的索引的本质就只有一句话,以空间换时间。索引的作用索引关系型数据库为了加速对表中行数据检索的(磁盘存储的)数据结构索引的分类数据结构上面的分类HASH 索引等值匹配效率高不支持范围查找树形索引二叉树,递归二分查找法
MySQL优化之索引解析
2019-07-07

编程热搜

目录