MySQL数据库优化
Posted 老李笔记
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据库优化相关的知识,希望对你有一定的参考价值。
mysql数据库优化
1、优化步骤
- 慢查询的开启并捕获;
- explain+慢SQL分析;
- show profile查询SQL在Mysql服务器里面的执行细节和生命周期情况;
- SQL数据库服务器的参数调优。
2、索引优化口诀
- 全值匹配我最爱;
- 左前缀法则:带头大哥不能死,中间兄弟不能断;
- 索引列上不计算(计算、函数、自动或手动类型转换);
- 范围之后全失效;
- 尽量使用覆盖索引(减少select *);
- mysql 不等于(!= 或 <>)会全表扫描;
- is null,is not null 索引会失效;
- like % 加右边;
- 字符串里有引号;
- 少用or,用它索引会失效;
【优化总结口诀】
全值匹配我最爱,最左前缀要遵守;
带头大哥不能死,中间兄弟不能断;
索引列上少计算,范围之后全失效;
Like百分写最右,覆盖索引不写星;
不等空值还有or,索引失效要少用。
3、Explain 执行计划
3.1、Extra
- Using filesort; [性能差] 文件排序(需要尽快优化)
- Using temporary; [性能差] 使用了临时表保存中间结果 。常见于排序和分组中。(如果可以的话,必须优化)
- Using index;[性能好]
- Using where;
- Using join buffer; 使用了连接缓存(可考虑调整Buffer大小);
- impossible where;(比如:select * from a where name=‘123’ and name=‘456’)
- select tables optimized away;
- 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数据库优化的主要内容,如果未能解决你的问题,请参考以下文章