设为首页 加入收藏

TOP

mysql不被人知的秘密(二)
2014-11-24 07:28:07 来源: 作者: 【 】 浏览:3
Tags:mysql 秘密
e:mysql服务器的上线时间

Slow_queries:慢查询的次数

Com_select:查询操作的次数

Com_insert:插入操作的次数

Com_update:更新操作的次数

Com_delete:删除操作的次数

#2.优化查询

##2.1用explain和describe分析查询语句

注使用索引查询记录时,一定要注意索引的使用情况 ->>见上面使用索引的注意事项

我们将上面用过的explain来分析

explain select * from student where num=2;

执行结果如下:

1.id :select语句的编号

2.select_type:select语句的类型

#simple:简单查询,不包含连接查询和子查询

#primary:主查询或最外层的查询语句

#union:连接查询的第二个或后面的查询语句

2.table:查询的表

4.type:表的连接类型

#system:表中只有一条记录

#const:表中有多条记录,但只从表中查询一条

#all:对表进行了完整的扫描

#eq_ref:多表连接时,后面的表使用了union或者primary key

#ref:多表连接时,后面使用了普通索引

#unique_subquery:子查询使用了unique或者primary key

#index_subquery:子查询使用了普通索引

#range:查询语句给出了查询范围

#index:对表中的索引进行了完整的扫描

5.possible_keys:查询中可能使用的索引

6.key:查询使用的索引

7.key_len:索引字段的长度

8.ref:表示使用哪个列或常数与索引一起查询记录

9.rows:查询的行数

10:extra:查询附加信息

describe 语句使用方法和explain一样。

##2.2 优化子查询

多用连接查询来代替子查询

为什么呢?

因为子查询时,mysql需要为内层查询结果建立一个临时表,然后外层查询在临时表中查找,查询完后需要撤销临时表。

而连接查询不需要建立临时表,所以比子查询快。

##2.3优化插入记录的速度

插入记录时,索引,唯一性校验等都会影响到插入记录的速度。而且,一次插入多条记录和多次插入记录所耗费的时间也不同。

1.禁用索引

插入数据时,mysql会根据表的索引对插入的记录进行排序,降低插入速度。解决这个问题可以在插入记录之前禁用索引,等到插入完毕后在开启。

alter table 表名disable keys; //禁用索引

alter table 表名enable keys; //开启索引

2.禁用唯一性检查

插入数据时,mysql会对插入的记录进行唯一性检查,会降低插入速度。

set unique_checks=0; //禁用唯一性

set unique_checks=1; //开启唯一性

3.优化insert语句

insert into 表名values

(......),

(......);

insert into 表名values (......);

insert into 表名values (......);

上面两种插入方法,第一种与数据库的连接等操作,明显比第二种快。

##2.3分析表,检查表和优化表

分析表:分析关键字的分布

检查表:检查表是否存在错误

优化表:消除删除或者更新造成的空间浪费

当执行下面三个操作时,mysql数据库会给表加一个只读锁,只能读取记录,不能更新和插入记录。

1.分析表

analyze table 表名1 [,表名2....];

2.检查表

check table 表名1 [,表名2....] [option];

option有五个参数:quick,fast,changed,medium,extended ->>执行效率依次降低

-->option选项只对MyISAM类型的表有效。

3.优化表

optimize table 表名1 [,表名2....];

-->只能优化表中的varchar,blob和text字段

如果一个表使用了text或blob这样的数据类型,那么更新,删除等就会造成的磁盘空间的浪费。操作完成后,以前分配的磁盘空间不会自动回收。

使用optimize可以将磁盘碎片整理出来,以便利用。

下面是一些mysql基本使用命令。

一:mysql查看基本命令

(1):查看当前有哪些数据库

show databases;

(2):使用mysql数据库

use test;

(3):查看当前数据库下的表

show tables;

(4):查看上述grade表建立的命令

show create table grade;

(5):查看student表的结构

desc student;

(6):查看数据库支持的存储引擎

show engines;

show engines \G ; // \G让结果更美观

(7):查看默认存储引擎

show variables like 'storage_engine';

二:mysql的修改表

(1)将grade表的course字段的数据类型修改为varchar(20)

alter table grade modify course varchar(20);

(2)将s_num字段的位置改到course前面

alter table grade modify s_num int(10) after id;

(3)将grade字段改名为score

alter table grade change grade score varchar(10);

(4)删除grade的外键约束

alter table grade drop foreign key grade_fk;

(5)将grade的存储引擎修改为INnoDB

alter grade engine=INnoDB;

(6)将student的address字段删除

alter table student drop address;

(7)在student表中增加名位phone的字段

alter table student add phone int (10);

(8)将grade的表名修改为gradeinfo

lter table grade rename gradeinfo;

(9):删除student表

drop table student; //由于先前已经删除外键,所以才能删除父表studnet

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇解决MySQL无法远程访问的方法 下一篇MySQL远程访问授权及快速修复

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Asus Armoury Crate (2025-12-26 02:52:33)
·WindowsFX (LinuxFX) (2025-12-26 02:52:30)
·[ Linux运维学习 ] (2025-12-26 02:52:27)
·HTTPS 详解一:附带 (2025-12-26 02:20:37)
·TCP/IP协议到底在讲 (2025-12-26 02:20:34)