MySQL数据库性能优化该如何入手
今天小杨给大家分享一篇关于数据库查询优化,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显。关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情。无论是小白还是职场的老手,都是必须掌握的一个手段。如果你对此了解不多,这块内容还是好好看看!
第一步:找到那些查询速度慢的语句
开启慢日志查询:这个主要是帮我们收集时间较长的SQL语句,需要在配置文件my.cnf里面设置查询的时间(long_query_time),以及存储的路径(slow_query_log_file),并对其开启(slow_query_log)。对上面参数配置完成后,执行语句,查看是否开启,下图为开启的结果:<br>
show variables like 'slow_query%';

第二步:对找到的sql进行分析
1、 使用mysql的explain分析语句的状态:
如上图,explain出来的信息有十多列,通过key列的值,我们可以看到使用到的索引,如果没触发到索引的话,可以查看上篇文章,尽可能的触发索引。
2、 如果开启了show profile,该功能默认是关闭的,使用前需开启。
show variables like 'profiling';

SHOW PROFILES

可以通过上面的语句 Duration 列观看耗时
show profile cpu,block io for query id;/*id为show profiles列表中的Query_ID*/

也可以通过上面的语句,查看该语句更为具体的参数进行判断
第三步:找到问题的后对其进行性能的优化
1. 开启MySQL的查询缓存
这个可以有效的提高查询性能,当相同的查询被执行多次的时候,这些查询的结果会被放到缓存中,后续的查询直接返回缓存的结果。但是也有一些查询姿势会导致缓存无效,首先,想要查询缓存需要查询语句一样,另外条件查询中不能使用一些易变的函数,如NOW(),CURDATE()等
2. 为查询的字段建立索引
对经常查询的字段建立索引,当数据量大的时候,通过建立索引可以有效的帮我们提高查询的效率,但是也不是建太多的索引,不仅占磁盘,当我们插入和跟新的时候也需要去维护,影响效率
3. 尽量避免使用 `select *` 以及当查询一条数据的时候 用 `limit 1`
从数据库读取太多数据的时候,会影响到速度以及网络传输的负载,所以尽量使用具体字段代替,覆盖索引。当我们知道只想要一条数据的时候,当使用 `limit 1`时,数据库引擎会在找到符合数据后停止往下搜索,从而提高效率
4. 字段设计的时候最好使用 `NOT NULL`
首先NULL本身是需要占据存储空间的,另外一方面,当索引字段可以为NULL的时候,索引的效率会下降,除非你有特定的需要使用到NULL,不然还是尽可能的使用到 NOT NULL
5. 选择正确的存在引擎 MyISAM 和 InnoDB
MyISAM 适合于一些需要大量查询的应用,但其对于有大量写操作并不是很好。甚至你只是需要update一个字段,整个表都会被锁起来,而别的进程,就算是读进程都无法操作直到读操作完成。InnoDB 的趋势会是一个非常复杂的存储引擎,对于一些小的应用,它会比 MyISAM 还慢。他是它支持“行锁” ,于是在写操作比较多的时候,会更优秀。并且,他还支持更多的高级应用,比如:事务。
6. 对表进行水平拆分或者垂直拆分
- 水平拆分:当一张表的数据量大的时候(如登录表,用户表)随着时间的累加,数据量不断累加,这个时候我们可以将表拆分成多张表,对用户的名字或者id进行取模,从而分散存入到不同的表中,减少单表的压力
- 垂直拆分:当表的字段过多的时候,表占用空间很大,检索表的时候需要执行大量的IO,严重降低了性能,这个时候可以考虑将一些字段拆分到多张表中,可以考虑下三大范式。这样可以降低表的复杂度和字段的数目,从而达到优化的目的。
7. 避免索引的失效
日常中,我们建立了索引了,但是姿势不对也可能让我们全表扫描,总结一些日常的坑
- like 以%开头,索引无效;当like前缀没有%,后缀有%时,索引有效。
- where 等式的时候使用了进行函数、算术运算或其他表达式运算
- whre子句中使用!=或<>操作符、null值判断、使用 or 来连接条件,索引失效少用
- 使用联合索引没有遵守最左原则的时候,索引也无效
共同进步,学习分享
欢迎大家关注我的公众号【写代码的小杨】,相关文章、学习资料都会在里面更新,整理的资料也会放在里面。
觉得写的还不错的就点个赞,加个关注呗!点关注,不迷路,持续更新!!!
MySQL数据库性能优化该如何入手的更多相关文章
- mysql数据库性能优化(包括SQL,表结构,索引,缓存)
优化目标减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所决定的,大部分数据库操作中超过90%的时间都是 IO 操作所占用的,减少 IO 次数是 SQL 优化中需要第一优先考虑,当 ...
- MySQL 数据库性能优化之索引优化
接着上一篇 MySQL 数据库性能优化之表结构,这是 MySQL数据库性能优化专题 系列的第三篇文章:MySQL 数据库性能优化之索引优化 大家都知道索引对于数据访问的性能有非常关键的作用,都知道索引 ...
- MySQL数据库性能优化专题
摘录: 书:<MySQL性能调优与架构设计> 一个系列: (按顺序排一下) MySQL 数据库性能优化之缓存参数优化 http://isky000.com/database/mysql-p ...
- MySQL 数据库性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感兴趣 ...
- MySQL数据库性能优化:表、索引、SQL等
一.MySQL 数据库性能优化之SQL优化 注:这篇文章是以 MySQL 为背景,很多内容同时适用于其他关系型数据库,需要有一些索引知识为基础 优化目标 减少 IO 次数IO永远是数据库最容易瓶颈的地 ...
- MySQL数据库性能优化与监控实战(阶段四)
MySQL数据库性能优化与监控实战(阶段四) 作者 刘畅 时间 2020-10-20 目录 1 sys数据库 1 2 系统变量 1 3 性能优化 1 3.1 硬件层 1 3.2 系统层 1 3.3 软 ...
- 浅谈MySQL 数据库性能优化
MySQL数据库是 IO 密集型的程序,和其他数据库一样,主要功能就是数据的持久化以及数据的管理工作.本文侧重通过优化MySQL 数据库缓存参数如查询缓存,表缓存,日志缓存,索引缓存,innodb缓存 ...
- Mysql数据库性能优化(一)
参考 http://www.jb51.net/article/82254.htm 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要 ...
- MySQL数据库性能优化
mysql查询优化: 1.新增字段索引,查询时若使用到or关键字,则两个字段都需建立索引才能生效 2.sql语句包含子查询,mysql会创建临时表查询结束后删除,影响效率,所以应尽可能使用join替代 ...
随机推荐
- [论文阅读笔记] Structural Deep Network Embedding
[论文阅读笔记] Structural Deep Network Embedding 本文结构 解决问题 主要贡献 算法原理 参考文献 (1) 解决问题 现有的表示学习方法大多采用浅层模型,这可能不能 ...
- 行者APP适配国外环境问题解决
(本文1151字,阅读约5分钟) 玩骑行的同伴都知道,长途骑行,第一需要好的硬件,如大腿发动机.车子.装备等:二是需要好的软件,如意志.有氧能力.骑行app等. 到雅加达后,才发现在国内用了几年的黑鸟 ...
- 如何去掉a标签的下划线
首先来了解下<a>标签的一些样式: <a>标签的伪类样式 一组专门的预定义的类称为伪类,主要用来处理超链接的状态.超链接文字的状态可以通过伪类选择符+样式规则来控制.伪类选择符 ...
- 国内操作系统OS分析(上)
国内操作系统OS分析(上) 一.操作系统(OS)概述 操作系统(OS,Operating System),是管理.控制计算机软硬件资源的计算机程序,并为用户提供一个与系统交互的操作界面.OS是配置在计 ...
- Fine-Tuning微调原理
Fine-Tuning微调原理 如何在只有60000张图片的Fashion-MNIST训练数据集中训练模型.ImageNet,这是学术界使用最广泛的大型图像数据集,它拥有1000多万幅图像和1000多 ...
- 开源电路分享のFalling Star Board
设计初衷 想自己做个能连网的时钟,结合RT-thread,显示个天气预报什么的,想想就挺有趣的.考虑到当前的芯片价格,和后续的设计,万一还有个啥奇妙的想法呢,就把这个做成了核心板. 一开始就只做了最小 ...
- 《精通 ASP.NET Core MVC (第七版)》开始发售
学习 Web 开发技术很难吗?没有适合的学习资料,确实很枯燥,很难.如果有一本如同良师益友的优秀图书辅助,就很轻松,一点也不难! 对于优秀的技术图书来说,必须从读者的角度来编写,而不是从作者的角度来编 ...
- 基于Android平台的图书管理系统的制作(4)
讲解完学生.职员.书籍这些基础层之后,我们可以来了解一些应用层的活动. 新书上架.借阅排行.黑名单.图书馆介绍.图书馆新闻. 新书上架是查询数据库里的Book表,将最近注册的五本书的基本信息(若图书馆 ...
- 【题解】Luogu P2889 [USACO07NOV]挤奶的时间Milking Time
Luogu P2889 [USACO07NOV]挤奶的时间Milking Time 题目描述 传送门Bessie is such a hard-working cow. In fact, she is ...
- Pytest学习笔记4-assert断言
前言 pytest作为单元测试框架,自然少不了断言功能,用过unittest的人都知道,在unittest中有丰富的断言方法,比如assertEqual().assertIn().assertTrue ...