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

MySQL高性能索引策略和查询性能优化

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

MySQL高性能索引策略和查询性能优化

MySQL高性能索引策略和查询性能优化

前缀索引和索引选择性

有时候需要索引很长的字符,这会让索引变得大且慢。一个策略是模拟哈希索引

通常可以索引开始的部分字符,这样可以大大解约索引空间,提高索引效率。但这样会降低索引的选择性。

索引的选择性:不重复的索引值(也成为基数)和数据表的记录总数比值。索引的选择性越高则查询效率越高,因为选择性高的索引可以在查找时过滤更多的行。唯一索引的选择性为1,是选择性最好的。

前缀索引是一种能使索引更小更快的办法,但也有缺点:

MySQL无法使用ORDER BY和GROUP BY,也无法使用覆盖扫描。

聚簇索引

聚簇索引并不是一种单独的索引类型,是一种数据存储方式。

当表有聚簇索引时,它的数据行实际上存放在索引的叶子页。

聚簇:数据行和相邻的键值紧凑的存储在一起。

如果没有定义主键,InnoDB会选择一个唯一的非空索引代替。

如果没有这样的索引,会隐式定义一个主键作为聚簇索引。

聚簇索引的缺点

  • 插入速度严重依赖插入顺序。按照主键的顺序插入是加载数据到InnoDB表中速度最快的方式。但如果不是按照主键顺序加载数据,最好使用OPYIMIZE TABLE重新组织表。

  • 基于聚簇索引的表在插入新行,或者主键被迁移时,可能会“页分裂”。当行的主键值要求必须将这一行插入到某个已满的页中时,存储引擎会将该页分裂成两个页面来容纳该行,这是一次页分裂操作。页分裂会导致表占用更多的磁盘空间。

覆盖索引

通常大家会根据查询的WHERE条件创建合适的索引,设计优秀的索引也可以使用索引来直接获取列的数据。

如果索引的叶子结点已经包含要查询的数据,那还要什么必要再回表查询呢?如果一个索引包含所有需要查询的字段的值,我们称之为“覆盖索引”。
image

延迟关联

使用inner join做子查询。在查询的第一个阶段可以使用覆盖索引。虽然无法使用索引覆盖整个查询,但比完全无法利用索引覆盖的好。

冗余和重复索引

索引越大越多,插入数据越慢。

可以使用Percona Toolkit中的pt-duplicate-key-checker分析表结构找出冗余的索引。

单表建多少个索引才合适?

  • 大表,主键有一个唯一索引。再有一到两个组合索引,最多三个索引足够用了。

  • 索引数量不能超过4个/表。

  • 一切服从应用需要。在一张表上创建多少索引,创建什么样的索引,并无一定之规。不能说一张表上有了 7个索引,就不能再创建第 8个索引了。

  • 索引的多少取决于具体的业务场景。

  • 在oltp中,表经常需要insert等,那么索引不能过多,一般超过3个就会对性能有影响。

  • 在olap中如果表只是用于查询,那么建多个索引也无妨。

索引和锁

索引可以让查询锁定更少的行。但是,如果索引无法过滤掉无效的行,那么在InnoDB检索到数据并返回给服务器层以后,MySQL才能用那个用WHERE子句,这时已经无法避免锁定行了:InnoDB已经锁定了这些行。

mysql> select actor_id from sakila.actor where actor_id < 5 and actor_id <> 1 for update;

虽然这条查询返回的是2,3,4,但是实际上获取了1-4的排他锁。

话句话说,存储引擎的操作是“找小于5的记录”,服务器并没有告诉InnoDB可以过滤第1行的WHERE条件。注意到EXPLAIN的Extra列出现了“Using where”,这表示MySQL将存储引擎返回行以后再应用WHERE过滤条件。

using where 代表MYSQL服务器层在存储引擎层返回行以后再应用WHERE过滤条件

查询性能优化

对于性能低下的查询,通过两个步骤来分析非常有效:

确认应用程序是否在检索大量超过需要的数据。这意味着访问了过多的行或者是过多的列。

确认MySQL服务器层是否在分析大量超过需要的数据行。

  • 比如使用 * 来返回全部列,其实有些列是用不到的,应该精简,或者说重复查询相同改的数据,这应该把这种数据放到缓存里,下次查先从缓存取,热点数据每次取可以给加过期时间。

  • 确认EXPLAIN中扫描的行数和访问类型
    在EXPLAIN中的type列是访问类型,从全表扫描、索引扫描、范围扫描、唯一索引查询、常数引用(全索范唯),他们的查询速度是从慢到快。

Re

《高性能MySQL》

免责声明:

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

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

MySQL高性能索引策略和查询性能优化

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

下载Word文档

猜你喜欢

MySQL高性能索引策略和查询性能优化

前缀索引和索引选择性有时候需要索引很长的字符,这会让索引变得大且慢。一个策略是模拟哈希索引。通常可以索引开始的部分字符,这样可以大大解约索引空间,提高索引效率。但这样会降低索引的选择性。索引的选择性:不重复的索引值(也成为基数)和数据表的记录总数比值。索引的选
MySQL高性能索引策略和查询性能优化
2017-05-17

MySQL高性能索引策略

前缀索引和索引选择性有时候需要索引很长的字符,这会让索引变得大且慢。一个策略是前面提到的模拟哈希索引。通常可以索引开始的部分字符,这样可以大大解约索引空间,提高索引效率。但这样会降低索引的选择性。索引的选择性:不重复的索引值(也成为基数)和数据表的记录总数比值
MySQL高性能索引策略
2021-10-14

PHP与MySQL索引的查询语句优化和索引返回的性能优化策略及其对性能的影响

数据库是现代应用开发中不可或缺的一部分,而针对数据库的查询语句优化和索引返回的性能优化是开发人员应该重点关注的问题。索引是一种用于提高数据库查询效率的重要数据结构,它通过在表中创建特定字段的索引来加速数据的查找和排序过程。本文将重点讨论PH
2023-10-21

MySQL数据库查询性能优化策略

优化查询使用Explain语句分析查询语句 Explain 用来分析 SELECT 查询语句,开发人员可以通过分析 Explain 结果来优化查询语句。 通过对查询语句的分析,可以了解查询语句的执行情况,找出查询语句执行的瓶颈,从而优化查询
2022-05-25

MySQL查询性能优化索引下推

目录前言1. 索引下推的作用2. 案例实践3. 索引下推配置4. 索引下推原理剖析5. 索引下推应用范围前言前面已经讲了mysql的其他查询性能优化方式,没看过可以去了解一下:MySQL查询性能优化七种方式索引潜水MySQL查询性能优
2022-08-16

PHP与MySQL索引的数据读取和查询优化的性能优化策略及其对性能的影响

摘要:在PHP与MySQL开发中,高效的数据读取和查询优化对于提升应用程序的性能至关重要。本文将介绍一些性能优化策略,并通过具体的代码示例来说明其对性能的影响。索引的基本概念索引是一种数据结构,用于加速数据库的数据检索。在MySQL中,常见
2023-10-21

MySQL 索引优化与查询性能提升

MySQL 索引的优化是提升数据库查询性能的重要手段。通过合理设计索引、优化查询条件以及采取适当的优化策略,可以显著提高 MySQL 数据库的查询效率和整体性能。

深入探索Elasticsearch:高级查询技巧与性能优化策略

复合查询是 Elasticsearch 中一种组合多个查询的方式,以满足复杂的查询需求。它由多个单独的查询组成,并通过逻辑运算符(如must、should、must_not等)进行组合。复合查询可以提供更精确的查询结果,并可以根据特定的条件

SQL性能优化策略之索引优化方法

SQL优化是优化工作中经常会涉及的问题,由于早期的开发人员往往只关注于SQL功能的实现,而忽略了性能。特别是复杂的SQL,上线之后很少修改,一旦出现问题,即使是当初的开发人员自己也很难理清其中的业务逻辑,需要花费大量的时间去理解代码之间的
SQL索引性能2024-12-03

SQL性能优化策略之联合索引优化方法

LIS_REQUISITION_INFO表的访问先通过I_PRINT_TIME索引进行范围扫描,符合条件的记录回表之后再过滤,产生了大量的单块读。
SQL策略优化2024-12-03

如何优化Solr搜索性能以提高查询效率?(提升Solr搜索性能有哪些策略?)

优化Solr搜索性能策略涉及优化查询(使用相关查询参数、范围查询、短语查询和查询分析器)、优化索引(合理使用分片、选择合适的字段类型、启用复制因子和定期优化索引)、优化Solr配置(调整查询参数、启用索引缓存、优化并发和使用优化器)、优化硬件环境(使用高速存储、增加内存、使用多核CPU和优化网络配置)以及其他优化策略(使用实时获取、采用渐进式分页、使用faceting、监控和调整)。这些策略旨在提高查询相关性、减少查询时间并确保最佳搜索体验。
如何优化Solr搜索性能以提高查询效率?(提升Solr搜索性能有哪些策略?)
2024-04-02

mysql-查询性能优化

1、不要取出全部列,取出全部列,会让优化器无法完成索引覆盖扫描这类优化,还会为服务器带来额外的I/O、内存和CPU的消耗。应该严格禁止SELECT * 的写法。MySQL使用如下三种方式应用WHERE条件,从好到坏依次为:  1.1 在索引中使用WHERE条件
mysql-查询性能优化
2021-02-18

MySQL查询性能优化七种方式索引潜水

这篇文章主要介绍了MySQL查询性能优化七种方式索引潜水,文章为荣啊主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
2022-11-13

PHP与MySQL索引的数据更新和索引维护的性能优化策略及其对性能的影响

摘要:在PHP与MySQL的开发中,索引是优化数据库查询性能的重要工具。本文将介绍索引的基本原理和使用方法,并探讨索引对数据更新和维护的性能影响。同时,本文还提供了一些性能优化策略和具体的代码示例,帮助开发者更好地理解和应用索引。索引的基本
2023-10-21

PHP与MySQL索引的数据读取和查询缓存的优化策略及其对性能的影响

引言:在Web开发中,PHP和MySQL是两个极其重要的工具。PHP作为一种流行的服务器端脚本语言,用于开发动态网站和应用程序。而MySQL则是一个开源的关系型数据库管理系统,用于存储和管理数据。PHP和MySQL的结合为开发人员提供了强大
2023-10-21

索引为什么能提高查询性能....

昨天,有个女孩子问我提高数据库查询性能有什么立竿见影的好方法?这简直是一道送分题,我自豪且略带鄙夷的说,当然是加「索引」了。
索引2024-12-03

MySQL INSERT锁与数据库查询性能调优策略

使用批量插入数据:在插入大量数据时,可以考虑使用批量插入数据的方式,减少插入操作的次数,提高插入性能。使用LOAD DATA INFILE:如果需要导入大量数据到数据库中,可以考虑使用MySQL提供的LOAD DATA INFILE语句,效
MySQL INSERT锁与数据库查询性能调优策略
2024-08-14

PHP与MySQL索引的数据缓存和内存表的优化策略及其对查询性能的影响

引言:在开发和优化数据库驱动的应用程序时,PHP和MySQL是非常常见的组合。而在PHP与MySQL的交互中,索引的数据缓存和内存表的优化策略对于提高查询性能起着至关重要的作用。本文将介绍关于PHP与MySQL索引的数据缓存和内存表的优化策
2023-10-21

Elasticsearch分布式搜索中的查询优化策略(如何优化Elasticsearch分布式搜索的查询性能?)

Elasticsearch分布式搜索中的查询优化策略有助于提高性能。策略包括:分片和副本管理(分片数、副本数)索引设置优化(映射、字段数据、_all字段禁用)查询优化(过滤器、布尔查询、范围查询)分词和排序优化(分词器选择、排序脚本)查询缓存(减少重复查询开销)其他优化(热分片、异步查询、监控和调整)
Elasticsearch分布式搜索中的查询优化策略(如何优化Elasticsearch分布式搜索的查询性能?)
2024-04-02

编程热搜

目录