前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL优化

MySQL优化

作者头像
allsmallpig
发布2021-02-25 14:39:45
6440
发布2021-02-25 14:39:45
举报
文章被收录于专栏:allsmallpi博客

转载自http://www.cnblogs.com/luyucheng/p/6323477.html

一、SQL语句优化

(1)使用limit对查询结果的记录进行限定 (2)避免select *,将需要查找的字段列出来 (3)使用连接(join)来代替子查询 (4)拆分大的delete或insert语句

二、选择合适的数据类型

(1)使用可存下数据的最小的数据类型,整型 < date,time < char,varchar < blob (2)使用简单的数据类型,整型比字符处理开销更小,因为字符串的比较更复杂。如,int类型存储时间类型,bigint类型转ip函数 (3)使用合理的字段属性长度,固定长度的表会更快。使用enum、char而不是varchar (4)尽可能使用not null定义字段 (5)尽量少用text,非用不可最好分表

三、选择合适的索引列

(1)查询频繁的列,在where,group by,order by,on从句中出现的列 (2)where条件中<,<=,=,>,>=,between,in,以及like 字符串+通配符(%)出现的列 (3)长度小的列,索引字段越小越好,因为数据库的存储单位是页,一页中能存下的数据越多越好 (4)离散度大(不同的值多)的列,放在联合索引前面。查看离散度,通过统计不同的列值来实现,count越大,离散程度越高:

代码语言:javascript
复制
mysql> SELECT COUNT(DISTINCT column_name) FROM table_name;

四、使用命令分析

(1)SHOW查看状态 1.显示状态信息

代码语言:javascript
复制
mysql> SHOW [SESSION|GLOBAL] STATUS LIKE '%Status_name%';

session(默认):取出当前窗口的执行 global:从mysql启动到现在 (a)查看查询次数(插入次数com_insert、修改次数com_insert、删除次数com_delete)

代码语言:javascript
复制
mysql> SHOW STATUS LIKE 'com_select';

(b)查看连接数(登录次数)

代码语言:javascript
复制
mysql> SHOW STATUS LIKE 'connections';

(c)数据库运行时间

代码语言:javascript
复制
mysql> SHOW STATUS LIKE 'uptime';

(d)查看慢查询次数

代码语言:javascript
复制
mysql> SHOW STATUS LIKE 'slow_queries';

(e)查看索引使用的情况:

代码语言:javascript
复制
mysql> SHOW STATUS LIKE 'handler_read%';

handler_read_key:这个值越高越好,越高表示使用索引查询到的次数。 handler_read_rnd_next:这个值越高,说明查询低效。 2.显示系统变量

代码语言:javascript
复制
mysql> SHOW VARIABLES LIKE '%Variables_name%';

3.显示InnoDB存储引擎的状态

代码语言:javascript
复制
mysql> SHOW ENGINE INNODB STATUS;

(2)EXPLAIN分析查询

代码语言:javascript
复制
mysql> EXPLAIN SELECT column_name FROM table_name;

explain查询sql执行计划,各列含义: table:表名; type:连接的类型     -const:主键、索引;     -eq_reg:主键、索引的范围查找;     -ref:连接的查找(join)     -range:索引的范围查找;     -index:索引的扫描;     -all:全表扫描; possible_keys:可能用到的索引; key:实际使用的索引; key_len:索引的长度,越短越好; ref:索引的哪一列被使用了,常数较好; rows:mysql认为必须检查的用来返回请求数据的行数; extra:using filesort、using temporary(常出现在使用order by时)时需要优化。     -Using filesort  额外排序。看到这个的时候,查询就需要优化了     -Using temporary 使用了临时表。看到这个的时候,也需要优化 (3)PROFILING分析SQL语句 1.开启profile。查看当前SQL执行时间

代码语言:javascript
复制
mysql> SET PROFILING=ON; 
mysql> SHOW profiles;

2.查看所有用户的当前连接。包括执行状态、是否锁表等

代码语言:javascript
复制
mysql> SHOW processlist;

(4)PROCEDURE ANALYSE()取得建议 通过分析select查询结果对现有的表的每一列给出优化的建议

代码语言:javascript
复制
mysql> SELECT column_name FROM table_name PROCEDURE ANALYSE();

(5)OPTIMIZE TABLE回收闲置的数据库空间

代码语言:javascript
复制
mysql> OPTIMIZE TABLE table_name;

对于MyISAM表,当表上的数据行被删除时,所占据的磁盘空间并没有立即被回收,使用命令后这些空间将被回收,并且对磁盘上的数据行进行重排(注意:是磁盘上,而非数据库)。 对于InnoDB表,OPTIMIZE TABLE被映射到ALTER TABLE上,这会重建表。重建操作能更新索引统计数据并释放成簇索引中的未使用的空间。 只需在批量删除数据行之后,或定期(每周一次或每月一次)进行一次数据表优化操作即可,只对那些特定的表运行。 (6)REPAIR TABLE修复被破坏的表

代码语言:javascript
复制
mysql> REPAIR TABLE table_name;

(7)CHECK TABLE检查表是否有错误

代码语言:javascript
复制
mysql> CHECK TABLE table_name;

五、定位慢查询

MySQL慢查询

六、分区

MySQL分区和分表

七、配置优化

MySQL配置优化

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018/08/19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、SQL语句优化
  • 二、选择合适的数据类型
  • 三、选择合适的索引列
  • 四、使用命令分析
  • 五、定位慢查询
  • 六、分区
  • 七、配置优化
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档