要调整InnoDB
表查询,请在每个表上创建一组适当的索引。有关详细信息,请参见 第8.3.1节“ MySQL如何使用索引”。请遵循以下InnoDB
索引准则:
- 因为每个
InnoDB
表都有一个 主键(无论您是否请求一个主键),所以请为每个表指定一组主键列,这些列用于最重要且时间紧迫的查询中。 - 不要在主键中指定太多或太长的列,因为这些列值在每个辅助索引中都是重复的。当索引包含不必要的数据时,用于读取此数据的I / O和用于对其进行缓存的内存将降低服务器的性能和可伸缩性。
- 不要 为每一列创建单独的 二级索引,因为每个查询只能使用一个索引。很少测试的列或只有几个不同值的列上的索引可能对任何查询都没有帮助。如果对同一个表有很多查询,测试不同的列组合,请尝试创建少量的 串联索引,而不是大量的单列索引。如果索引包含结果集所需的所有列(称为 覆盖索引),则查询可能完全避免读取表数据。
- 如果索引列不能包含任何
NULL
值,请NOT NULL
在创建表时将其声明为。当优化器知道每一列是否包含NULL
值时,它可以更好地确定哪个索引对查询最有效 。 - 您可以
InnoDB
使用第8.5.3节“优化InnoDB只读事务”中的技术优化表的 单查询事务 。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
3418次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
923次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
545次阅读
2025-04-17 17:02:24
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
373次阅读
2025-04-30 17:37:37
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
309次阅读
2025-04-28 11:01:25
SQL优化 - explain查看SQL执行计划(下)
金同学
303次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
298次阅读
2025-04-30 12:17:54
MySQL 官方准备了 3 个月的羊毛,万万没想到 8 天就被薅秃了,看看JieKeXu怎么说?
青年数据库学习互助会
291次阅读
2025-05-09 10:07:42
MySQL 8.4 新特性深度解析:功能增强、废弃项与移除项全指南
JiekeXu
255次阅读
2025-04-18 20:21:32
4月“墨力原创作者计划”获奖名单公布!
墨天轮编辑部
220次阅读
2025-05-13 16:21:59
TA的专栏
热门文章
我的故障分析及处理思路分享(李真旭)
2020-10-22 11220浏览
公共子表达式消除(Common Subexpression elimination,CSE)
2020-08-26 6243浏览
Oracle数据库的跟踪和分析方法
2020-10-02 5091浏览
2.5.9使用systemd管理MySQL服务器
2020-10-20 4585浏览
初探华为云GaussDB (for MySQL)
2020-12-11 3900浏览
最新文章
28.4.4 INFORMATION_SCHEMA INNODB_BUFFER_POOL_STATS 表
2024-09-29 114浏览
28.4.3 INFORMATION_SCHEMA INNODB_BUFFER_PAGE_LRU 表
2024-09-29 71浏览
28.4.2 INFORMATION_SCHEMA INNODB_BUFFER_PAGE 表
2024-09-29 71浏览
28.4.1 INFORMATION_SCHEMA InnoDB 表参考
2024-09-29 75浏览
28.3.50 INFORMATION_SCHEMA VIEW_TABLE_USAGE 表
2024-09-29 73浏览