首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql索引优化实例1

目录 目录 前言 当前情况介绍 分析及优化 结果 前言 PS:本文只讲解了一个实例,中间用到了两个mysql索引相关概念,覆盖索引和最左前缀索引,需要读者自行学习一下....所以最后的决定是,不使用缓存或者lucene等花里胡哨的东西,就使用mysql,优化一下索引,争取到做的单个查询300ms内,这样加上一些带代码层面的优化,接口能接近1s左右....分析及优化 使用explain命令分析执行计划,第一个sql的索引使用已经OK,where语句全部命中了索引,且查询字段是完全覆盖了索引的....分析第二个语句,使用索引,但是仅使用了联合索引的第一个,因为不半部分是个表达式,无法使用索引. 第三个语句,虽然存在两个对应字段的独立索引,但是根据执行计划显示,mysql没有使用第二个索引....联系邮箱:huyanshi2580@gmail.com 更多学习笔记见个人博客——>呼延十 var gitment = new Gitment({ id: 'Mysql索引优化实例1', // 可选

56140

正确使用索引和Explain工具,MySQL性能提升实例

type: 这个字段是MySQL连接使用的表的方式。这可能是explain输出中最重要的字段。它可以指示缺失的索引,还可以显示应该如何重写查询。...ref:索引列的所有匹配行都为来自前一个表的每个行组合读取。与=或操作符相比,这种类型的连接通常用于索引列。 fulltext:联接使用表全文索引。...possible_keys:显示MySQL可以使用的键,以便从表中查找行。这些键可以在实践中使用,也可以不使用。 key:指示MySQL使用的实际索引MySQL总是寻找可以用于查询的最优密钥。...值,如在此列中使用filesort或使用临时性值,可能表示查询麻烦。 Explain输出格式的完整文档可以在MySQL官方页面找到。...通常,如果ORDER BY是从表中按字段进行的,而不是联接顺序中的第一个,则不能使用索引。 不要通过表达式。表达式和函数不允许使用索引。 注意一个大的极限值( LIMIT value)。

1.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql前缀索引使用,Mysql:前缀索引索引

    可以像普通索引一样使用mysql前缀索引吗?...一般来说,我很想知道使用前缀索引时是否有任何警告.不考虑性能,如果任何查询必须以不同方式编写,或者客户端是否必须执行额外逻辑,则更多....解决方法: 如果你想一下,MySQL仍会给你正确的答案,即使没有索引…它只是不会那么快……所以,是的,你仍然会得到一个正确的答案前缀索引....需要注意的事实是,优化器不会对某些操作(如排序或分组)使用前缀索引,因为它没有为此目的覆盖足够的列数据....并且,前缀索引不能用作覆盖索引.覆盖索引是指SELECT中的所有列恰好包含在一个索引中的情况(加上可选的主键,因为它也总是存在).优化器将直接从索引读取数据,而不是使用索引来标识要在主表数据中查找的行.

    5.3K20

    正确使用MySQL索引

    MySQL之所以能够高效的检索数据,可以说全赖索引之功。在索引使用过程中,要注意一下几点。 1、MySQL使用索引时候,采用的是最左匹配原则。...在计算列里无法使用索引。...select * from t where ABS(a)=constant; select * from t where f(a)=constant;//f为任意函数 3、MySQL在否定条件中不能使用索引...例如,where条件里面有、not in、not exists的时候,即便是这些判断字段上加上索引,也不会起作用。 4、MySQL在join中连接字段类型如果不一致,则不能使用索引。...另外尽快避免使用like查询,特别是like '%name',这种左边模糊匹配的情况,使用MySQL无法使用索引。如果出现隐式的字符类型转换,MySQL也不能使用索引,相当于在判断列上加了函数一样。

    1K10

    一百万数据索引实例測试–mysql

    : 1.where和order by等的字段建立索引 2.使用唯一索引:对于last_login,area等字段反复的次数比較少,能够使用索引;而sex无非就两个值:性别1。...不值得索引 3.多列索引:不要为每个列单独建立索引。这样并不能将mysql索引的效率最大化。使用索引合并策略” 4.选择合理的索引列顺序:索引列的顺序意味着索引首先依照最左列进行排序。...4.为每个列单独建立索引,不能将索引的效率最大化,应该使用索引合并策略,即依据查询条件。...建立联合索引 5.联合索引的顺序问题:将选择性高的索引放到前面 6.依据资料建立索引意味着索引依照最左列进行排序,然后事第二列。以此类推。...推荐书籍:高性能mysql(第三版) PDF版本号的:http://pan.baidu.com/s/1sjJIyRV 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    93020

    MySQL索引使用规则总结

    如何加快查询,最直接有效的办法就是增加索引,在不使用索引的情况下试图采用其他方式加快查询就是在浪费时间。本文先介绍下MySQL索引的基本数据结构,再对索引的基本规则做下总结。...在使用索引情况下来分析下关联查询的过程: 从数据表table1中选择第一个数据行,看这个数据行包含什么样的值 对数据表table2中使用索引,直接找到与数据表table1的值相匹的数据行。...创建了N个列的符合索引,实际上创建了MySQL能够使用的n个索引。例如某表的复合索引 index(国家,省份,城市)。...如果改成 Where col_name like ‘string%’查询依string开头的字符串就可以使用col_name上的索引 5.自动类型转换可能会阻止索引使用;例如: select * from...参考: 1、MySQL技术内幕:InnoDB存储引擎 2、MySQL技术内幕:第4版 3、MySQL高效编程 4、MySQL的官方手册 5、http://km.oa.com/articles/show/

    3.9K00

    mysql全文索引使用

    正好前一段时间项目有一个新的需求,就重新调研了一下mysql的全文索引,并对mysql的全文索引进行了压测,看看性能怎么样。以判断是否使用。——可想而知,性能不是很好。...在前面的几篇博客中,小编提到过,mysql中常用的表的引擎有MyIsam 和 Innodb, 其中,默认存储引擎InnoDB,MYSQL5.6以前是不支持全文索引,新版本MYSQL5.6的InnoDB支持全文索引...随着Mysql的升级,我们使用众多的还是Innodb。...使用like的缺点是,如果不是前缀索引索引会失效。所以如果根据不同的内容来查的时候,自然很难命中索引。这样全文检索就登场。...MATCH()函数使用的字段名,必须要与创建全文索引时指定的字段名一致。

    1.4K20

    mysql中联合索引abc 使用bac_mysql 联合索引

    mysql 联合索引详解 联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。...两个或更多个列上的索引被称作复合索引。利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引。...(`id`),KEY `a` (`a`,`b`,`c`)) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT=’测试表’ AUTO_INCREMENT=1 ;使用...and a=’a’ and b=’b’ suoyinwhere c=’c’ and b=’b’ and a=’a’ suoyin从上面的分析可以得到下面的结论1、在where里面的条件与顺序无关,只和使用到的字段有关...,这样才能最大程度的使用联合索引 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/142076.html原文链接:https://javaforall.cn

    1.7K40

    MySQL使用 普通索引 or 唯一索引

    MySQL中可以创建普通索引与唯一索引,这两种索引的区别是: 普通索引(Non-Unique Index),也称为非唯一索引,它允许索引中的条目具有重复的键值。...普通索引的主要目的是加快查询速度,它并不关心数据的唯一性。 普通索引的特点: 可以包含重复的索引键值。 适用于快速查找具有相同索引值的多个记录的场景。 不保证数据的唯一性。...数据页目前如果在内存中,则直接更新,如果不在内存中,可以使用Change Buffer缓存对数据的更新操作,从而减少磁盘I/O操作,提高更新性能。...但只有普通索引可以使用Change Buffer,而唯一索引由于需要检查唯一性约束(从磁盘加载数据后,再进行判断),不能使用Change Buffer。...所以在业务可以接受的情况下,优先考虑使用普通索引,尤其是频繁插入和更新场景。因为普通索引可以配合Change Buffer使用,从而优化更新操作。

    16710

    mysql如何使用前缀索引_MySQL的前缀索引你是如何使用

    灵魂3连问: 什么是前缀索引? 前缀索引也叫局部索引,比如给身份证的前 10 位添加索引,类似这种给某列部分信息添加索引的方式叫做前缀索引。 为什么要用前缀索引?...前缀索引能有效减小索引文件的大小,让每个索引页可以保存更多的索引值,从而提高了索引查询的速度。...但前缀索引也有它的缺点,不能在 order by 或者 group by 中触发前缀索引,也不能把它们用于覆盖索引。 什么情况下适合使用前缀索引?...当字符串本身可能比较长,而且前几个字符就开始不相同,适合使用前缀索引;相反情况下不适合使用前缀索引,比如,整个字段的长度为 20,索引选择性为 0.9,而我们对前 10 个字符建立前缀索引其选择性也只有...WHERE x_name = ‘1892008.205824857823401.800099203178258.8904820949682635656.62526521254’; 查询时间:3.291s 当使用第一位字符创建前缀索引

    2.5K20

    Mysql索引-不会使用索引的场景

    可以看到extra的值是Using index,说明使用了覆盖索引。虽然使用索引,但是也是全索引扫描。...此时我们可以使用下面语句,实现我们需要的结果,下面语句也用上了索引的快速定位能力,但是比较繁琐 mysql> select count(*) from tradelog where -> (t_modified...我们发现第一行使用索引,这个索引是建立在主键索引上的,并且扫描了一行,但是第二行,我们发现没有使用索引,进行了全表扫描。...,一个个判断tradeid的值是否符合 正常按照我们的理解,第二行的tradeid它也是有索引的,应该也是使用索引才对,为什么没有使用索引的 其实第三步,相当是下面语句 mysql> select...,将不会使用索引快速定位能力,这里我们就明白了,为什么被驱动表会全表扫描 作为对比我们可以下面语句看看效果 mysql>select l.operator from tradelog l , trade_detail

    1.2K20

    MySQL索引失效及使用索引的优缺点

    联合索引使用时遵循最左匹配原则,如果不是从最左列开始时,整个索引失效,如果最左匹配则依次往右使用索引,直到碰到不匹配的地方之后生效之前匹配到的索引 ? ?...like查询失效 使用模糊查询时,%只有在最右方的时候才能生效 为title设置一个单独的索引 ? ? ? 查询中含有不等于或者or则索引不生效 ? ? ?...注意事项 在进行索引使用测试时,可能会因为测试数据太少从而MySQL会认为查询语句走全表扫描比走索引更有效,所以会自动去除索引,为避免测试结果误导可使用如下方式强制MySQL使用索引 explain...select * from book FORCE index(索引名称) where price=1+1; 使用索引的优点 唯一索引或主键索引可以保证数据库表的唯一性 可以提高查询效率和性能 加速表连接的速度...加快排序的效率 使用索引的缺点 每次更新修改删除都需要维护索引、从而消耗性能 索引文件会占用物理空间

    3.3K60

    MySQL优化以及索引使用

    MySQL优化 选取最适用的字段长度 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。...确保order by / group by 只根据一个表上的字段进行,这样才有使用索引进行排序分组的可能性. 使用外键 锁定表的方法可以维护数据的完整性,但是它却不能保证数据的关联性。...如果要在MySQL使用外键,一定要记住在创建表的时候将表的类型定义为事务安全表InnoDB类型。该类型不是MySQL表的默认类型。...删除不再使用或者很少使用索引 MySQL索引最多包含16个索引列 条件带like 注意事项 like 模糊查询中,右模糊查询(abc%)会使用索引,而(%abc)和(%abc%)会放弃索引使用全表扫描...=和in可以乱序 联合查询 联合查询,子查询等多表操作时关连字段要加索引,Rmman大佬说,不建议使用子查询 索引使用位置 ?

    85642

    mysql联合索引使用规则

    1’),(‘2′,’2′,’2′,’2′,’2’) 使用MySql Explain开始分析题目结果: A选项: 结果可以看出,c1,c2,c3,c4均使用到了该索引,而我们对A结果稍作更改: 将c2...条件去掉后: 根据索引最左原则,c2字段没有使用索引,c2之后的字段都不能使用索引。...下面2图我们对比下索引最左原则: 上图结果显示直接使用c3是全表查询,无法使用索引的,所以c3字段使用索引的前提是c1,c2两字段均使用索引。 即是索引的最左原则(左前缀原则)。...由key_len长度确定,只有c1一个字段使用索引。 D选项: order by 和group by 类似,字段顺序与索引一致时,会使用索引排序;字段顺序与索引不一致时,不使用索引。...综上所述问题答案: A:四个字段均使用了该索引 B:c1,c2字段使用了该索引 C:c1字段使用索引 D:c1字段使用索引 E:c1,c2字段使用了该索引 总结: 索引的最左原则(左前缀原则),如(

    1.4K20

    Mysql索引原理(八)」使用索引扫描做排序

    MySQL有两种方式可以生成有序的结果:通过排序操作;或者按索引顺序扫描;如果explain出来的type列的值为index,则说明MySQL使用索引扫描来做排序。...这基本上都是随机I/O,因此按索引顺序读取数据的速度通常要比顺序地全表扫描慢,尤其是在I/O密集型的工作负载时。 MySQL可以使用同一个索引既满足排序,又用于查找行。...只有当索引的顺序和ORDER BY子句的顺序完全一致,并且所有列的排序方向都一样时,MySQL才能使用索引结果来做排序。...ORDER BY子句和查找型查询的限制是一样的:需要满足索引的最左前缀的要求;否则,MySQL都需要执行排序操作,而无法利用索引排序。...,所以MySQL无法使用索引的其余列 ... where rental_date>'2019-10-10' order by inventory_id desc,customer_id 5、在inventory_id

    1.2K10

    sql mysql like查询使用索引

    使用msyql进行模糊查询的时候,很自然的会用到like语句,通常情况下,在数据量小的时候,不容易看出查询的效率,但在数据量达到百万级,千万级的时候,查询的效率就很容易显现出来。...结论:后置百分号可以用到索引,前置百分号和两侧百分号用不了索引。...一般情况下like模糊查询的写法为(field已建立索引): SELECT `column` FROM `table` WHERE `field` like '%keyword%'; 上面的语句用explain...解释来看,SQL语句并未用到索引,而且是全表搜索,如果在数据量超大的时候,可想而知最后的效率会是这样 对比下面的写法: SELECT `column` FROM `table` WHERE `field...` like 'keyword%'; 这样的写法用explain解释看到,SQL语句使用索引,搜索的效率大大的提高了!

    3.6K20
    领券