文章插图
欢迎关注头条号:JAVA小野猫
实践中如何优化MySQL
实践中,MySQL的优化主要涉及SQL语句及索引的优化、数据表结构的优化、系统配置的优化和硬件的优化四个方面,如下图所示:
文章插图
SQL语句及索引的优化
SQL语句的优化
SQL语句的优化主要包括三个问题,即如何发现有问题的SQL、如何分析SQL的执行计划以及如何优化SQL,下面将逐一解释 。
- 怎么发现有问题的SQL?(通过MySQL慢查询日志对有效率问题的SQL进行监控)
long_query_time的默认值为10,意思是运行10s以上的语句 。慢查询日志的相关参数如下所示:
文章插图
通过MySQL的慢查询日志,我们可以查询出执行的次数多占用的时间长的SQL、可以通过pt_query_disgest(一种mysql慢日志分析工具)分析Rows examine(MySQL执行器需要检查的行数)项去找出IO大的SQL以及发现未命中索引的SQL,对于这些SQL,都是我们优化的对象 。
通过explain查询和分析SQL的执行计划
使用 EXPLAIN 关键字可以知道MySQL是如何处理你的SQL语句的,以便分析查询语句或是表结构的性能瓶颈 。通过explain命令可以得到表的读取顺序、数据读取操作的操作类型、哪些索引可以使用、哪些索引被实际使用、表之间的引用以及每张表有多少行被优化器查询等问题 。当扩展列extra出现Using filesort和Using temporay,则往往表示SQL需要优化了 。
优化SQL语句
- 优化insert语句:一次插入多值;
- 应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描;
- 应尽量避免在 where 子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描;
- 优化嵌套查询:子查询可以被更有效率的连接(Join)替代;
- 很多时候用 exists 代替 in 是一个好的选择 。
索引优化
建议在经常作查询选择的字段、经常作表连接的字段以及经常出现在order by、group by、distinct 后面的字段中建立索引 。但必须注意以下几种可能会引起索引失效的情形:
- 以“%(表示任意0个或多个字符)”开头的LIKE语句,模糊匹配;
- OR语句前后没有同时使用索引;
- 数据类型出现隐式转化(如varchar不加单引号的话可能会自动转换为int型);
- 对于多列索引,必须满足最左匹配原则(eg,多列索引col1、col2和col3,则 索引生效的情形包括col1或col1,col2或col1,col2,col3) 。
数据库表结构的优化
数据库表结构的优化包括选择合适数据类型、表的范式的优化、表的垂直拆分和表的水平拆分等手段 。
选择合适数据类型
- 使用较小的数据类型解决问题;
- 使用简单的数据类型(mysql处理int要比varchar容易);
- 尽可能的使用not null 定义字段;
- 尽量避免使用text类型,非用不可时最好考虑分表;
表的范式的优化
一般情况下,表的设计应该遵循三大范式 。
表的垂直拆分
- 把含有多个列的表拆分成多个表,解决表宽度问题,具体包括以下几种拆分手段:
- 把不常用的字段单独放在同一个表中;
- 把大字段独立放入一个表中;
- 把经常使用的字段放在一起;
- 这样做的好处是非常明显的,具体包括:拆分后业务清晰,拆分规则明确、系统之间整合或扩展容易、数据维护简单 。
表的水平拆分
表的水平拆分用于解决数据表中数据过大的问题,水平拆分每一个表的结构都是完全一致的 。一般地,将数据平分到N张表中的常用方法包括以下两种:
- 对ID进行hash运算,如果要拆分成5个表,mod(id,5)取出0~4个值;
- 针对不同的hashID将数据存入不同的表中;
- 表的水平拆分会带来一些问题和挑战,包括跨分区表的数据查询、统计及后台报表的操作等问题,但也带来了一些切实的好处:
- 表分割后可以降低在查询时需要读的数据和索引的页数,同时也降低了索引的层数,提高查询速度;
推荐阅读
- 金寨县油坊店乡白茶合作社获省级示范称号
- 恐龙时期的鳄鱼 地球上的第一种恐龙大约出现在两亿四千万年前
- 梧州高档礼品级六堡茶挺进内蒙古茶市
- 茶企升级 打造茶叶市场名牌迫在眉睫
- 三江县,茶产业全面升级 加速推广生态茶园
- 你属于七级性爱的第几级
- Docker下搭建Apache+PHP+Mysql
- 半小时MySQL基础入门,值得收藏
- 四川茶企竹叶青君临天下顶级红茶面世
- phpMyAdmin导入WordPress的MySQL数据库时报错