加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql必读MySql的优化步骤介绍(推荐)

发布时间:2020-12-12 01:10:16 所属栏目:MySql教程 来源:网络整理
导读:《Mysql必读MySql的优化步骤介绍(推荐)》要点: 本文介绍了Mysql必读MySql的优化步骤介绍(推荐),希望对您有用。如果有疑问,可以联系我们。 MySql优化的一般步骤: MYSQL实例 1.通过show status 命令了解各种sql的执行效率 MYSQL实例 SHOW STATUS提供msyql

《Mysql必读MySql的优化步骤介绍(推荐)》要点:
本文介绍了Mysql必读MySql的优化步骤介绍(推荐),希望对您有用。如果有疑问,可以联系我们。

MySql优化的一般步骤:MYSQL实例

1.通过show status 命令了解各种sql的执行效率MYSQL实例

SHOW STATUS提供msyql服务器的状态信息MYSQL实例

一般情况下,我们只需要了解以”Com”开头的指令MYSQL实例

show session status like ‘Com%':显示当前的连接的统计结果MYSQL实例

show global status like ‘Com%' :显示自数据库上次启动至今的统计结果MYSQL实例

注:默认是session级别的MYSQL实例

其中Com_XXX表示XXX语句所执行的次数.
MYSQL实例

重点注意:Com_select,Com_insert,Com_update,Com_delete通过这几个参数,可以容易地了解到当前数据库的应用是以插MYSQL实例

入更新为主还是以查询操作为主,以及各类的SQL大致的执行比例是多少.MYSQL实例

另外,还有几个参数需要注意下:MYSQL实例

show status like ‘Connections'// 试图连接MySQL服务器的次数MYSQL实例

show status like ‘Uptime'//服务器工作的时间(单位秒)MYSQL实例

show status like ‘Slow_queries'//慢查询的次数 (默认是10秒中就当做是慢查询,如下图所示)MYSQL实例

MYSQL实例

a) 如何查询mysql的慢查询时间MYSQL实例

Show variables like 'long_query_time';MYSQL实例

b) 修改mysql 慢查询时间MYSQL实例

set long_query_time=2//如果查询时间超过2秒就算作是慢查询MYSQL实例

2. 定位执行效率较低的SQL语句(dql出现问题的概率较dml的大)MYSQL实例

问题是:如何在一个项目中,找到慢查询的select语句?MYSQL实例

答案:mysql支持把慢查询语句记录到日志文件中.程序员需要修改php.ini的配置文件,默认情况下,慢查询记录是不开启的.MYSQL实例

开启慢查询记录的步骤:MYSQL实例

打开 my.ini,找到 [mysqld] 在其下面添加MYSQL实例

long_query_time = 2MYSQL实例

log-slow-queries = D:/mysql/logs/slow.log #设置把日志写在那里,可以为空,系统会给一个缺省的文件MYSQL实例

例子:我们数据表中有1千万条的数据量MYSQL实例

DQL语句:SELECT * FROM order_copy WHERE id=12345;MYSQL实例

MYSQL实例

查询耗时:19s>2s,所以mysql会将该条select语句记录到慢查询日志中MYSQL实例

SELECT * FROM order_copy WHERE id=12345的执行时间:MYSQL实例

添加索引前:19sMYSQL实例

添加索引后:0.08sMYSQL实例

3.通过explain分析低效率的SQL语句的执行情况MYSQL实例

使用explain分析该dql语句:MYSQL实例

EXPLAIN SELECT * FROM order_copy WHERE id=12345
MYSQL实例

会产生如下信息:
MYSQL实例

select_type:表示查询的类型.
MYSQL实例

table:输出结果集的表
MYSQL实例

type:表示表的连接类型(system和const为佳)
MYSQL实例

possible_keys:表示查询时,可能使用的索引
MYSQL实例

key:表示实际使用的索引
MYSQL实例

key_len:索引字段的长度
MYSQL实例

rows:扫描的行数
MYSQL实例

Extra:执行情况的描述和说明MYSQL实例

注意:要尽量避免让type的结果为all,extra的结果为:using filesortMYSQL实例

MYSQL实例

4.确定问题并采取相应的优化措施MYSQL实例

常用的优化措施是添加索引.添加索引,我们不用加内存,不用改程序,不用调sql,只要执行个正确的'create index',查询速度就可能提高百倍千倍.但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的I/O.MYSQL实例

例如:给字段id添加索引:MYSQL实例

ALTER TABLE order_copy ADD PRIMARY KEY(id)MYSQL实例

给1千万的数据添加primary key 需要耗时: 428秒(7分钟)MYSQL实例

EXPLAIN SELECT * FROM order_copy WHERE id=12345MYSQL实例

MYSQL实例

正是因为给id添加了索引,才使得rows的结果为1MYSQL实例

但是索引并不是可以随便添加的,以下几种情况需牢记在心:MYSQL实例

较频繁的作为查询条件字段应该创建索引MYSQL实例

select * from order_copy where id = $idMYSQL实例

唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件MYSQL实例

select * from order_copy where sex='女'MYSQL实例

更新非常频繁的字段不适合创建索引MYSQL实例

select * from order_copy where order_state='未付款'MYSQL实例

不会出现在WHERE子句中字段不该创建索引MYSQL实例

索引的类型:MYSQL实例

PRIMARY 索引 => 在主键上自动创建INDEX 索引 => 就是普通索引UNIQUE 索引 => 相当于INDEX + UniqueFULLTEXT => 只在MYISAM 存储引擎支持,目的是全文索引,在内容系统中用的多,在全英文网站用多(英文词独立). 中文数据不常用,意义不大 国内全文索引通常 使用 sphinx 来完成.MYSQL实例

索引的使用MYSQL实例

建立索引 create [UNIQUE|FULLTEXT] index index_name on tbl_name (col_name [(length)] [ASC | DESC],…..);
alter table table_name ADD INDEX [index_name] (index_col_name,...)MYSQL实例

添加主键(索引) ALTER TABLE 表名 ADD PRIMARY KEY(列名,..); 联合主键MYSQL实例

删除索引 DROP INDEX index_name ON tbl_name;
alter table table_name drop index index_name;删除主键(索引)比较特别: alter table t_b drop primary key;查询索引(均可) show index from table_name;
show keys from table_name;
desc table_Name;MYSQL实例

以上就是小编为大家带来的MySql的优化步骤介绍(推荐)全部内容了,希望大家多多支持编程之家PHP~MYSQL实例

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读