MySQL优化-阿里云开发者社区

开发者社区> 周彬彬> 正文

MySQL优化

简介: MySQL优化
+关注继续查看

MySQL

1. 优化SQL语句

MySQL慢日志的开启

查看数据库是否开启了慢查询日志
SHOW VARIABLES LIKE 'slow_query_log';
查看数据库是否将未使用索引的SQL记录到日志中
SHOW VARIABLES LIKE 'log_queries_not_using_indexes';
查看慢查询日志记录的慢查询日志时间
SHOW VARIABLES LIKE 'log_query_time';
查看慢查询日志文件存放位置
SHOW VARIABLES LIKE 'slow_query_log_file';
设置MySQL数据库开启慢查询日志
SET GLOBAL slow_query_log = on;
设置慢查询日志文件存储位置
SET GLOBAL slow_query_log_file='';
打开慢查询日志存储为设置索引的SQL
SET GLOBAL log_queries_not_using_indexes = on;
设置记录的慢查询日志超时时间
SET GLOBAL log_query_time = 1;

慢查询日志的存储格式
#time:  查询的开始时间
#user@host: 查询主机用户信息
#query_time: SQL的执行信息
#set timestamp: SQL执行时间
#select concat :执行的SQL语句

MySQL慢查询日志分析工具

mysqldumpslow -h

通过慢查询日志发现有问题的SQL

1.发现查询次数多且占用时间长的SQL(多:使用基于内存的数据库或使用缓存,长:优化SQL语句)
2.未命中索引的SQL(优化SQL语句添加特定索引优化)

使用explain查看SQL执行计划:查询结果属性说明

id select_type table type possible_keys key key_len ref rows extra
说明 查询id 查询类型 使用的表 类型 可能使用的索引 应用索引 索引长度 引用 返回行数 扩展说明

2.优化索引

选择合适的列建立索引

在where从句,group by从句,order by从句,on从句中出现的的列创建索引。
索引列的字段长度越小越好。
离散度大的列放到联合索引的前面。

索引的优化

1.避免使用重复及冗余的索引
2.去掉因业务变更,未使用的索引

3.数据库结构优化

优化数据大小

设计表以最小化磁盘空间,尽量使用最小化的数据大小来存储数据。

优化MySQL数据库数据类型

1.选择合适类型的数据类型,存储数据
2.使用可以存下你的数据的最小数据类型
3.尽可能使用简单的数据类型
4.尽可能使用not null定义字段,采用默认值方式
5.尽量少使用text类型,非用不可时最好使用分表的方式
6.数据库中不要存储二进制文本,图片,音频等数据。而要存储数据的网络路径
7.使用反范式化设计,设计一定的冗余字段,以减少多表联合查询。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
mysql优化三
1. 为查询缓存优化你的查询 大多数的MySQL服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被MySQL的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中,这样,后续的相同的查询就不用操作表而直接访问缓存结果了。
743 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
2503 0
mysql优化一
1.show global status      可以列出MySQL服务器运行各种状态值 2.show variables            查询MySQL服务器配置信息     一、慢查询 mysql> show variables like ‘%slow%‘; +-----...
548 0
[MySQL优化案例]系列 — slave延迟很大优化方法
[MySQL优化案例]系列 — slave延迟很大优化方法
26 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
11017 0
+关注
15
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《Nacos架构&原理》
立即下载
《看见新力量:二》电子书
立即下载
云上自动化运维(CloudOps)白皮书
立即下载