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

mysql复合索引普通索引总结

( 转 ) mysql复合索引普通索引总结 对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。例如索引是key index (a,b,c)....复合索引的结构与电话簿类似,人名由姓和名构成,电话簿首先按姓氏对进行排序,然后按名字对有相同姓氏的人进行排序。...而且由于使用相当多的内存来存储复合索引的列的值,其后果是内存溢出和性能降低。 复合索引排序的优化: 复合索引只对和索引排序相同或相反的order by 语句优化。...在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所允许的最大索引全文索引文本字段上的普通索引只能加快对出现在字段内容最前面的字符串(也就是字段内容开头的字符)进行检索操作...如果字段里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什么作用了。这种检索往往以的形式出现,这对MySQL来说很复杂,如果需要处理的数据量很大,响应时间就会很长。

2.8K20

MySQL唯一索引普通索引

InnoDB; insert into t(id, name, k) values (1, 'Java', 100), (2, 'Python', 200), (3, 'Go', 300), (5, 'MySQL...', 500), (6, 'Spark', 600) 我们使用上节的SQL进行分析普通索引和唯一索引的区别。...普通索引,查找到(500,5)这条记录后,还需要查找下一个记录,直到碰到第一个不满足k=500条件的记录 唯一索引,由于索引具有唯一性,所以查找到第一个满足条件的记录后就会停止继续检索 唯一索引带来的查询性能提升几乎微乎其微...唯一索引普通索引的插入 假设我们在表中需要插入一条新的数据(4, 'Flink', 400),InnoDB对于唯一索引普通索引的处理有些区别: 假设记录要更新的目标页在内存中,处理流程如下: 如果是唯一索引...唯一索引普通索引 唯一索引普通索引在查询性能上基本没有差别,但在更新上普通索引会快于唯一索引。所以在可以选择普通索引的前提下尽可能选择普通索引

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

    MySQL 加锁范围三——普通索引普通字段

    2 普通索引 普通索引等值查询 —— 数据存在 mysql> begin; select * from t where c = 210 for update; 直接分析 data_locks 表意向锁...普通索引等值查询 —— 数据不存在 mysql> begin; select * from t where c = 211 for update; 直接分析 data_locks 表意向锁; 索引 idx_c...普通索引范围查询 mysql> begin; select * from t where c > 210 and c <= 215 for update; 对于锁住 idx_c 索引的 215 的前开后闭区间是可以理解的...从而得出普通索引普通字段的结论。...普通索引 普通索引等值查询,因为不能确定唯一性,所以即使定位到记录,也是会向后查询,直到查询到不为该值的记录,从而锁定该值的区间; 普通索引的锁也是加载该索引上的,如果涉及到存在的记录,会对该主键加行锁

    2K10

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

    MySQL中可以创建普通索引与唯一索引,这两种索引的区别是: 普通索引(Non-Unique Index),也称为非唯一索引,它允许索引中的条目具有重复的键值。...普通索引的主要目的是加快查询速度,它并不关心数据的唯一性。 普通索引的特点: 可以包含重复的索引键值。 适用于快速查找具有相同索引值的多个记录的场景。 不保证数据的唯一性。...唯一索引创建方法: CREATE UNIQUE INDEX uidx_email ON customers(email); 选择普通索引还是唯一索引?...所以在业务可以接受的情况下,优先考虑使用普通索引,尤其是频繁插入和更新场景。因为普通索引可以配合Change Buffer使用,从而优化更新操作。...普通索引改成唯一索引后,某个业务的库内存命中率突然从 99% 降低到了 75%,整个系统处于阻塞状态,更新语句全部堵住。

    16710

    Mysql 索引排序

    image.png sql 中 order by 排序可能发生2种情况: 1)对应覆盖索引,直接在索引上查询时,就是有序的,不需要另外处理排序 2)没有使用到索引,先取出数据,形成临时表做 file sort...示例目标 取出来的数据本身就是有序的,利用索引排序 示例分析 例如 有一个商品表,现在想取出某个分类下的商品,按照价格排序 sql : ... where category_id=N order...by price 目前只对分类ID做了索引,这时 order by 操作必然进行了单独的排序操作 使用 explain 分析这个sql语句时,会看到: Extra Using where;Using...filesort 改进 现在添加一个索引,category_id和price 的联合索引 再使用 explain 分析这个sql语句时,会看到: Extra Using where 可以看到没再使用filesort...,这样就利用了索引排序,因为按照索引取出来的数据本身有序,order by 操作时用到了索引,一看本身就是有序的,就不再需要file sort操作

    2K60

    MySQL选择普通索引还是唯一索引(216)

    普通索引和唯一索引 基本概述 MySQL中可以创建普通索引与唯一索引,这两种索引的区别是: 普通索引(Non-Unique Index),也称为非唯一索引,它允许索引中的条目具有重复的键值。...普通索引的主要目的是加快查询速度,它并不关心数据的唯一性。 普通索引的特点: 可以包含重复的索引键值。 适用于快速查找具有相同索引值的多个记录的场景。 不保证数据的唯一性。...普通索引创建方法: CREATE INDEX idx_email ON customers(email); 唯一索引(Unique Index)是一种数据库索引,它要求索引中的所有键值都是唯一的。...所以在业务可以接受的情况下,优先考虑使用普通索引,尤其是频繁插入和更新场景。因为普通索引可以配合Change Buffer使用,从而优化更新操作。...普通索引改成唯一索引后,某个业务的库内存命中率突然从 99% 降低到了 75%,整个系统处于阻塞状态,更新语句全部堵住。

    16110

    Mysql如何选择唯一索引普通索引

    相信大家对唯一索引普通索引是有一定的了解的,那么在不同的业务场景,使用唯一索引还是普通索引呢,比如下面的场景 假设你在维护一个账户系统,每一个人都有一个唯一的身份证,而业务也能保证他的唯一性,此时我们设置唯一索引普通索引其实都是可以的...,也就是上图的右下角的数据页,然后通过数据页内容通过二分法定位记录 对于普通索引,查询到满足的而第一个记录后,需要向后继续寻找,直到不满足条件 对于唯一索引,由于索引的唯一性,查询到数据后,直接停止查询...,既然已经在内存中了,我们直接更新内存会更快,就没有必要使用change buffer了,因此唯一索引的更新是不会使用change buffer,只有普通索引可以使用....change buffer使用场景 从上面分析我可以知道cahnge buffer对于唯一索引不起作用,只能使用在普通中,问题是普通索引中一定会起到加速作用吗 因为merge的时候是整整进行数据更新的时候...索引的选择和实践 普通索引和唯一索引选择,其实,这类索引在查询能力上是没有差别,主要考虑的是对更新性能的影响,所以建议选择普通索引

    1.8K20

    mysql学习笔记(四)普通索引还是唯一索引

    这一篇主要来分析下如何选择普通索引和唯一索引,以及他们在查询时候的原理。 一、change buffer mysql引擎在查询的时候在存储引擎中提供了内存来帮助我们提高查询的效率。...mysql在内存与数据页之间使用了change buffer的概念来帮助我们提示更新的效率。...1、普通索引 对于普通索引,根据二分查找算法找到满足条件的记录后,还需要继续查找下一个记录,直到不满足条件为止。...另外上面的例子中,change buffer并不适合在唯一索引中使用。 三、唯一索引普通索引的选择 首先在查询方面,他们的性能其实没有一点差别。...如果考虑到更新的性能,并且可以保证业务上做出更新的幂等那么我建议还是优先使用普通索引

    98020

    MySQL实战之普通索引和唯一索引,应该怎么选择?

    1.前言在之前的文章中,我们讲解了索引的基本概念,相信你已经了解了唯一索引普通索引的区别。今天我们就来讨论一下,在不同的业务场景下,应该选择普通索引,还是唯一索引?...现在我要问你的是,从性能的角度考虑,你选择唯一索引还是普通索引呢?选择的依据是什么呢?...这是,InnoDB的处理流程如下:对于唯一索引来说,找到3和5之间的位置,判断到没有冲突,插入这个值,语句执行结束对于普通索引来说,找到3和5之间的位置,插入这个值,语句执行结束这样看来,普通索引和唯一索引对更新语句性能影响的差别...而探究其原因后,我发现这个业务有大量插入数据的操作,而他在前一天把其中的某个普通索引改成了唯一索引。...5.索引选择和实践回到我们文章开头的问题,普通索引和唯一索引应该怎么选择,其实,这两类索引在查询能力上没有差别,主要考虑的是对更新性能的影响,所以,我建议你尽量使用普通索引

    1.7K01

    你确定分得清MySQL普通索引和唯一索引

    1 概念区分 普通索引和唯一索引 普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手段,例如学生表的身份证号码字段,我们人为规定该字段不得重复,那么就使用唯一索引。...于是现有俩选择: 给id_card字段创建唯一索引 创建一个普通索引 假定业务代码已保证不会写入重复的身份证号,这两个选择逻辑上都正确。但从性能角度考虑,唯一索引还是普通索引呢?...因此,唯一索引的更新不能使用change buffer,只有普通索引可使用。 4.4 适用场景 难道普通索引的所有场景,使用change buffer都可加速吗?...6 实践中的索引选择 普通索引和唯一索引究竟如何抉择?这两类索引在查询性能上没差别,主要考虑对更新性能影响。所以,推荐尽量选择普通索引。...参考 https://dev.mysql.com/doc/refman/8.0/en/innodb-change-buffer.html https://time.geekbang.org/column

    2.6K10

    MySQL普通索引和唯一索引到底什么区别?

    1 概念区分 普通索引 V.S 唯一索引 普通索引可重复,唯一索引和主键一样不能重复。...于是现在有如下选择: 在id_card创建唯一索引 创建一个普通索引 假定业务代码已经确保不会写入重复身份证号,这两个选择逻辑上都是正确的。 性能优化角度考虑,选择唯一索引还是普通索引呢?...不在内存 唯一索引 将数据页读入内存,判断到没有冲突,插入值,结束。 普通索引 将更新记录在change buffer,结束。...5 索引选择的最佳实践 普通索引、唯一索引在查询性能上无差别,主要考虑更新性能。所以,推荐尽量选择普通索引。 若所有更新后面,都紧跟对该记录的查询,那就该关闭change buffer。...参考 https://dev.mysql.com/doc/refman/8.0/en/innodb-change-buffer.html

    59010

    你分得清MySQL普通索引和唯一索引了吗?

    0 概念区分 普通索引和唯一索引 普通索引可以重复,唯一索引和主键一样不能重复。 唯一索引可以作为数据的一个合法验证手段,例如学生表的身份证号码字段,我们人为规定该字段不得重复,那么就使用唯一索引。...因此现在有两个选择 给id_card字段创建唯一索引 创建一个普通索引 如果业务代码已保证不会写入重复的身份证号,那这两个选择逻辑上都正确。 但从性能角度考虑,唯一索引还是普通索引呢?...普通索引和唯一索引对更新语句性能影响的差别,只是一个判断,只会耗费微小CPU时间。...探究其原因,发现该业务有大量插入数据操作,而DBA在前天把其中的某个普通索引改成了唯一索引。 change buffer的使用场景 普通索引的所有场景,使用change buffer都可加速吗?...4 实践中的索引选择 普通索引和唯一索引如何抉择。 这两类索引在查询性能上没差别,主要考虑对更新性能影响。 所以,推荐尽量选择普通索引

    2.2K11

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

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

    1.2K10

    MySQL普通索引和唯一索引到底什么区别?

    1 概念区分 普通索引 V.S 唯一索引 普通索引可重复,唯一索引和主键一样不能重复。 唯一索引可作为数据的一个合法验证手段,例如学生表的身份证号码字段,人为规定该字段不得重复,那么就使用唯一索引。...不在内存 唯一索引 将数据页读入内存,判断到没有冲突,插入值,结束。 普通索引 将更新记录在change buffer,结束。...5 索引选择最佳实践 普通索引、唯一索引在查询性能上无差别,主要考虑更新性能。所以,推荐尽量选择普通索引。 若所有更新后面,都紧跟对该记录的查询,就该关闭change buffer。...所以,当你有“历史数据”库,且出于成本考虑用机械硬盘,应该关注这些表里的索引,尽量用普通索引,把change buffer开大,确保“历史数据”表的数据写性能。...参考 https://dev.mysql.com/doc/refman/8.0/en/innodb-change-buffer.html

    2.7K41

    oracle删除索引_创建普通索引sql

    1.索引分类 a) 唯一索引, 作用是数据约束,保证数据唯一,还有就是数据索引,提高查询效率 b)一般索引,只有数据索引的作用, 2.唯一索引的建立 create unique index 索引名...on employee(empname); 3.一般索引 create index 索引名 on 表名(字段名) ok,现在我们为employee的address字段,添加一般索引 create index...); 这样,为field1,field2添加了唯一索引,field1和field2的组合是唯一的了 还可以指定索引排序 create index idx_test employee(field1...,field2 desc); 4.函数索引 如果在我们的查询条件使用了函数,那么索引就不可用了。...price字段上做的索引了 ok,我们来创建函数索引 create index index_price on product(nvl(price,0.0)); 5.索引的删除 drop index 索引

    82510

    Mysql索引原理(十四)」索引案例3-优化排序

    在这个学习案例中,最后要介绍的是排序。使用文件排序对小数据集是很快的,但如果个查询匹配的结果有上百万行的话会怎样?例如如果 WHERE子句只有sex列,如何排序?...对于那些选择性非常低的列,可以增加一些特殊的索引来做排序。...例如,可以创建(sex,rating)索引用于下面的查询: mysql> SELECT FROM profiles WHERE sex=‘M’ ORDER BY rating LIMIT...优化这类索引的另一个比较好的策略是使用延迟关联,通过使用覆盖索引查询返回需要的主键,再根据这些主键关联原表获得需要的行。这可以减少 MySQL扫描那些需要丢弃的行数。...下面这个查询显示了如何高效地使用( sex, rating)索引进行排序和分页 mysql> SELECT FROM profiles INNER JOIN (SELECT <primary

    60930

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券