MySQL数据库优化

Posted 老李笔记

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据库优化相关的知识,希望对你有一定的参考价值。

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、慢查询开启

# 查看是否开启:
show variables like '%slow_query_log%'

# 开启:
set global slow_query_log=1;

# long_query_time 是慢查询慢的控制参数,默认为10秒
#查询:
show variables like 'long_query_time%';
#修改阈值:
set global long_query_time=3;
###################注意:设置后不会里面变化,需要重新连接或新开一个会话才能看到修改值;
或者用:
show global variables like 'long_query_time';

#查询慢查询的数量:
show global status like '%Slow_queries%';

4.2、慢查询捕获(日志分析工具:mysqldumpslow)

mysqldumpslow 命令常用参数

s: 是表示按照何种方式排序;
c: 访问次数;
l:锁定时间
r:返回记录
t:查询时间
al:平均锁定时间
ar:平均返回记录数
at:平均查询时间
t:即为返回前面多少天的数据;
g:后边搭配一个正则匹配模式,大小写不敏感的;

# 得到返回记录集最多的10个SQL
mysqldumpslow -s r -t 10 /var/lib/mysql/hao-slow.log
# 得到访问次数最多的10个SQL
mysqldumpslow -s c -t 10 /var/lib/mysql/hao-slow.log
# 得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /var/lib/mysql/hao-slow.log
############### 另外建议在使用这些命令时结合 | 和 more 使用,否则有可能出现爆屏情况 ############
mysqldumpslow -s r -t 10 /var/lib/mysql/hao-slow.log | more

5、SQL数据库服务器的参数调优

5.1、影响order by 和 group by的参数

# 适量增加以下参数
sort_buffer_size
max_length_for_sort_data

6、技巧

6.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)

以上是关于MySQL数据库优化的主要内容,如果未能解决你的问题,请参考以下文章

Mysql的性能优化

面试中常问:mysql数据库做哪些优化也提高mysql性能

mysql对于大量数据,怎么进行优化

MySQL数据库Day03-数据库MySQL的优化

MySQL数据库Day03-数据库MySQL的优化

MySQL数据库Day03-数据库MySQL的优化