MySQL数据库优化
创始人
2024-06-01 05:25:44
0

MySQL数据库优化

1、优化步骤

  1. 慢查询的开启并捕获;
  2. explain+慢SQL分析;
  3. show profile查询SQL在Mysql服务器里面的执行细节和生命周期情况;
  4. SQL数据库服务器的参数调优。

2、索引优化口诀

  1. 全值匹配我最爱;
  2. 左前缀法则:带头大哥不能死,中间兄弟不能断;
  3. 索引列上不计算(计算、函数、自动或手动类型转换);
  4. 范围之后全失效;
  5. 尽量使用覆盖索引(减少select *);
  6. mysql 不等于(!= 或 <>)会全表扫描;
  7. is null,is not null 索引会失效;
  8. like % 加右边;
  9. 字符串里有引号;
  10. 少用or,用它索引会失效;

【优化总结口诀】
全值匹配我最爱,最左前缀要遵守;
带头大哥不能死,中间兄弟不能断;
索引列上少计算,范围之后全失效;
Like百分写最右,覆盖索引不写星;
不等空值还有or,索引失效要少用。

3、Explain 执行计划

3.1、Extra

  1. Using filesort; [性能差] 文件排序(需要尽快优化)
  2. Using temporary; [性能差] 使用了临时表保存中间结果 。常见于排序和分组中。(如果可以的话,必须优化)
  3. Using index;[性能好]
  4. Using where;
  5. Using join buffer; 使用了连接缓存(可考虑调整Buffer大小);
  6. impossible where;(比如:select * from a where name=‘123’ and name=‘456’)
  7. select tables optimized away;
  8. distinct;

4、技巧

4.1、永远小表驱动大表

# B是小表
select * from A where id in (select id from B)# A是小表
select * from A where exists(select 1 from B where B.id=A.id)

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...