MySql数据库优化可以从哪几个方面进行?

MySql数据库优化可以从哪几个方面进行?

http://blog.csdn.net/q602075961/article/details/71076390

1、数据库优化可以从以下几个方面进行:

MySql数据库优化可以从哪几个方面进行?

 

2、项目中,优化mysql之前,首先要开启慢查询日志,在分析慢查询日志.

1,查看所有日志状态: show variables like ‘%quer%’;
2,查看慢查询状态:show variables like ‘show%’


linux启用MySQL慢查询

 代码如下  

vim /etc/my.cnf
[mysqld]
slow-query-log = on # 开启慢查询功能
slow_query_log_file = /usr/local/mysql/data/slow-query.log # 慢查询日志存放路径与名称
long_query_time = 5 # 查询时间超过5s的查询语句
log-queries-not-using-indexes = on # 列出没有使用索引的查询语句

Windows下开启MySQL慢查询

MySQL在Windows系统中的配置文件一般是是my.ini找到[mysqld]下面加上

补充:

在my.cnf或者my.ini中添加log-queries-not-using-indexes参数,表示记录下没有使用索引的查询。比如:

 代码如下  
log-slow-queries=/data/mysqldata/slowquery.log # 慢查询日志存放路径与名称
long_query_time=5 # 查询时间超过5s的查询语句
log-queries-not-using-indexes # 列出没有使用索引的查询语句

 

 

 
MySql数据库优化可以从哪几个方面进行?
 
3、如何分析sql查询
explain返回各列的含义
extra列需要注意的返回值
Using filesort:看到这个的时候,查询就需要优化了。MYSQL需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行
Using temporary看到这个的时候,查询需要优化了。这里,MYSQL需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上
 
3.1  MySql内部函数explain(查询sql的执行计划)使用方法以及返回各列的含义
explain返回各列的含义
table:显示这一行的数据是关于哪张表的
type:这是重要的列,显示连接使用了何种类型。从最好到最差的连接类型为const、eq_reg、ref、range、index 和ALL
possible_keys:显示可能应用在这张表中的索引。如果为空,没有可能的索引。
key:实际使用的索引。如果为NULL,则没有使用索引。
keyjen:使用的索引的长度。在不损失精确性的情况下,长度越短越好
ref:显示索引的哪一列被使用了,如果可能的话,是一个常数
rows: MYSQL认为必须检查的用来返回请求数据的行数
 
实例1:mysql函数【max()】,最后一位注册用户的信息
进行查询操作,图一是没有加索引,图二是加了索引的,查询出来的type和rows字段也不相同。(参照上图字段段含义)
 
图一:
MySql数据库优化可以从哪几个方面进行?
图二:
MySql数据库优化可以从哪几个方面进行?
 
实例2: mysql函数【count() 】,获取注册用户男女人数
显然图三不是这个查询方法不是咱们想要的结果,图四和图五也一样,利用count()函数的特性null不统计,得到了我们想要的结果(图六)。
 
图三:
MySql数据库优化可以从哪几个方面进行?

图四:
MySql数据库优化可以从哪几个方面进行?

图五:
MySql数据库优化可以从哪几个方面进行?

图六:
MySql数据库优化可以从哪几个方面进行?
 
3.2 子查询的优化,通常情况下把子查询优化为join查询,但在优化的时候需要注意关联建是否有一对多的关系,要特别注意重复数据
MySql数据库优化可以从哪几个方面进行?
 
实例3:如图七和图八
图七:
MySql数据库优化可以从哪几个方面进行?
 
图八:
MySql数据库优化可以从哪几个方面进行?
 
 
3.3 GROUP BY的优化
MySql数据库优化可以从哪几个方面进行?
MySql数据库优化可以从哪几个方面进行?
 
实例4:获取每个用户爱好的数量。使用sql执行计划来排查,图九使用GROUP BY查询,关联的表会产生临时表和按照文件排序,sql优化之后(图十)就直接按照索引来查询,避免临时表的产生和文件形式排序。在数据量大的时候会大大减少对服务器的IO访问。
图九:
MySql数据库优化可以从哪几个方面进行?
 
图十:
MySql数据库优化可以从哪几个方面进行?
 
实例5:使用LIMIT一般都伴随着ORDER BY(如图十一),如果是没有索引的字段排序的的话会按照文件排序,全表查询会加大对服务器IO的访问。
图十一:
MySql数据库优化可以从哪几个方面进行?
 
优化方案一:使用主键进行排序,不会造成全表扫描,会减少
对服务器IO的访问。但是还有一个问题,当所查询的条数越往后,所扫描的条数也会越多(如图十三)
 
图十二:
MySql数据库优化可以从哪几个方面进行?
 
图十三:
MySql数据库优化可以从哪几个方面进行?
 
优化方案二:可以获取上一个主键的id来做一个范围查询来减少对服务器IO的访问(如图十四),但是因此还会出现另一个问题,要保证主键ID是连续的,当主键ID中间有缺少,会对我们查询出来的数据不对。
 

图十四:


MySql数据库优化可以从哪几个方面进行?

 


优化方案三:可以添加一个字段用于LIMIT查询,再加上索引,就和主键id产生同样的效果,但是这样会产生很多麻烦。
 
4 .1、如何选择合适的列建立索引
MySql数据库优化可以从哪几个方面进行?
 
说明:
1、如果一个索引可以包含所有字段的话,就称之为覆盖索引。当一张表里的数据少的话,就可以使用覆盖索引,这样就可以读取索引而不用读取表了。
2、索引字段越小越好,因为数据库里的数据是已页存储的,如果IO一次读取一页的数据很多,这样的话就可以提高服务器IO的效率。
3、在建立联合索引的时候,一定要把离散度大的放在前面,这样的话效果比较好

实例6:
通过count函数统计唯一值,值大的离散度就大,也就是说u_pass的离散度比大u_name,所以应该使用index(u_pass,u_name)
MySql数据库优化可以从哪几个方面进行?
4.2、索引的维护和优化
4.2.1重复索引
MySql数据库优化可以从哪几个方面进行?
 
4.2.2冗余索引
MySql数据库优化可以从哪几个方面进行?
 
 
4.2.3检查重复及冗余索引的工具
MySql数据库优化可以从哪几个方面进行?
 
4.2.4删除不用的索引
MySql数据库优化可以从哪几个方面进行?
说明:由于业务变更有些原来使用的索引现在不使用了也是需要清除的,这也是索引优化的一个方面了!
注意:再次的强调SQL和索引的优化对于数据库的优化是相当重要的,这一层的优化如果做好了,其他的优化也能起到一些作用否则其他的优化所能起到的作用是微乎其微的,这一层的优化也是成本最低效果最好的一层了,所以对于数据库的优化最好重点放在这一层。
 
5、数据库结构优化
5.1选择合适的数据类型
数据类型的选择,重点在于
合适二字,如何确定选择的数据类型是否合适?
1.使用可以存下你的数据的最小的数据类型。
2.使用简单的数据类型。Int要比varchar类型在mysql处理上简单。
3.尽可能的使用not null定义字段。
4.尽量少用text类型,非用不可时最好考虑分表。
 
实例:
int、bigint、smallint 和 tinyint范围
使用整数数据的精确数字数据类型。
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。
int
从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。
smallint
从 -2^15 (-32,768) 到 2^15 – 1 (32,767) 的整型数据。存储大小为 2 个字节。
tinyint
从 0 到 255 的整型数据。存储大小为 1 字节。
注释
在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时。
在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。 
 
实例:时间使用int类型
MySql数据库优化可以从哪几个方面进行?
 
实例:IP地址使用bigint类型
MySql数据库优化可以从哪几个方面进行?
 
5.2 表的范式化
 
什么是范式化?
MySql数据库优化可以从哪几个方面进行?
 
不符合第三范式的要求会出现的问题
MySql数据库优化可以从哪几个方面进行?

 
实例:
MySql数据库优化可以从哪几个方面进行?
 
 
5.3 表的反范式化的使用
MySql数据库优化可以从哪几个方面进行?
 
如我要查询订单商品表的下单人,电话,地址,订单id和下单时间sql语句如下:
MySql数据库优化可以从哪几个方面进行?
 
使用反范式化的表结构
MySql数据库优化可以从哪几个方面进行?
 
sqi语句的查询效率也会提升很多,数据库表结构的设计对sql的优化也起到了很大的作用
MySql数据库优化可以从哪几个方面进行?
 
5.4 表的垂直拆分
MySql数据库优化可以从哪几个方面进行?
 
5.5 表的水行拆分


当表的数据比较多的时候,可以选择将表进行水平拆分,水平拆分的本质并没有改变表的结构仅是将原本存放在同一个表中的数据放到了多个结构一样的表中。

 
水平拆分的方法:
MySql数据库优化可以从哪几个方面进行?
 
系统配置优化
 
6.1操作系统优化
MySql数据库优化可以从哪几个方面进行?
MySql数据库优化可以从哪几个方面进行?
 
6.2 MySql配置优化
MySql数据库优化可以从哪几个方面进行?
 
 
MySql数据库优化可以从哪几个方面进行?
SELECT engine,ROUND(SUM(data_length+index_length)/1024/2014,1) AS “Total MB” FROM INFORMATION_SCHEMA.TABLES WHERE table_schema not in (“information_schema”,”performance_schema”) GROUP BY ENGINE;
 
mysql常用配置参数1

MySql数据库优化可以从哪几个方面进行?
 
mysql常用配置参数2

MySql数据库优化可以从哪几个方面进行?
 
mysql常用配置参数3

MySql数据库优化可以从哪几个方面进行?
 
mysql常用配置参数4

MySql数据库优化可以从哪几个方面进行?
 
mysql常用配置参数5

MySql数据库优化可以从哪几个方面进行?
 
 
6.3 MySql
第三方配置工具
https://tools.percona.com/wizard
配置MySQL的配置文件使用工具更方便,主要就是调整配置的参数,值调整成什么样的参数才是合适的,估计需要补充各种基础知识不是三言两语说的清楚的。
就是将文本的配置方式变成了界面式的配置方式,不过经验在此时就非常的重要了,否则压根判断不出什么样的配置才是适合的配置!
 
 
 
7 服务器硬件优化
MySql数据库优化可以从哪几个方面进行?
 
MySql数据库优化可以从哪几个方面进行?
 
模拟数据库数据和sql语句下载:
密码:etf1

 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113570.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月15日 下午8:00
下一篇 2021年10月15日 下午9:00


相关推荐

  • 在 Mac 系统下安装 PyCharm 的方法

    在 Mac 系统下安装 PyCharm 的方法转载自 https blog csdn net 首先 进入 PyCharm 的官网 PyCharm PythonIDEfor 如上图所示 直接点击 DOWNLOADNOW 立即下载 如上图所示 JetBrains 提供了三个版本的 PyCharm 分别为 Windows m

    2026年3月27日
    2
  • WSAStartup函数的用途

    我们先来看看WSAStartup函数的原型intPASCALFARWSAStartup(WORDwVersionRequired,LPWSADATAlpWSAData);    可以这么理解,第一个参数提供必要信息(为了加载套接字库),第二个参数获取相关信息(获取相关信息)。看看下面的程序就明白了(其中wVersion比较重要):          WSACl

    2022年4月7日
    57
  • WORD域代码详解[通俗易懂]

    WORD域代码详解[通俗易懂]来自:百度文库WORD域代码详解我们在word中编辑文档时,有时会经常遇到要求输入数学公式的情况。虽然简单的加、减、乘、除等运算都可在键盘上直接输入,但遇到复杂的数学公式:如积分、开方、求和等符号时,就只能利微软的office套件中所带的工具”公式编辑器”来完成,但是在office套件的典型安装的过程中,并没有选择这个工具,那么有没有办法可以在word中直接输入这些符号呢?答案是肯定的,下

    2022年6月14日
    39
  • pycharm 创建 django 项目出错

    pycharm 创建 django 项目出错pycharm 创建 django 项目过程中 如果出现如下错误根据提示信息 找到问题发生的原因 pycharm2020 3 之前的版本 在创建 Django 项目的时候 会自动将 pip 升级到最新版本 并且安装 Django 的时候会使用 build dir 参数 但是 最新的 pip 在 20 版本后 取消了 build dir 参数 这就产生了冲突 也就是说 Pycharm 内部自动调用 pip 的时候 多提供了一个 build dir 参数 貌似这个机制还无法人工介入修改 知道了问题原因

    2026年3月18日
    1
  • Java多线程系列–“JUC锁”09之 CountDownLatch原理和示例

    Java多线程系列–“JUC锁”09之 CountDownLatch原理和示例概要前面对"独占锁"和"共享锁"有了个大致的了解;本章,我们对CountDownLatch进行学习。和ReadWriteLock.ReadLock一样,Coun

    2022年7月4日
    28
  • 如何创建HTML表单?html表单代码怎么写[通俗易懂]

    如何创建HTML表单?html表单代码怎么写[通俗易懂]html表单代码是什么?如何创建HTML表单?这些对于新手会感到陌生,下面我们为你总结一下html表单代码怎么写?以及html表单的创建?一:构建表单标签在文本编辑器中打开HTML文档,必须在<form>和</form>标签中键入HTML表单的内容。这些标签充当表单的容器,就像<div></div>容器标签一样。您可以在<form></form>标签内使用CSS或js,使您的表单看起来比较美观。2.打开<form&gt

    2022年8月11日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号