博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MYSQL 的optimize怎么用
阅读量:5994 次
发布时间:2019-06-20

本文共 1573 字,大约阅读时间需要 5 分钟。

  1. 当对表有大量的增删改操作时,需要用optimize对表进行优化。可以减少空间与提高I/O性能,命令optimize table tablename;假如有foo表且存储引擎为MyISAM。

mysql>optimize table foo;

+------------+----------+----------+----------+

| Table      | Op       | Msg_type | Msg_text |

+------------+----------+----------+----------+

| test.foo| optimize | status   | OK       |

+------------+----------+----------+----------+

  1. 如果是InnoDB引擎,首先查看innodb_file_per_table(是否独享表空间)。

mysql>show variables like 'innodb_file_per_table';

+-----------------------+-------+

| Variable_name         | Value |

+-----------------------+-------+

| innodb_file_per_table | OFF   |

+-----------------------+-------+

OFF代表开启共享表空间没有打开,即采用的是默认的共享表空间。这个时候可以在mysql的datadir路径下看到一个非常大的文件ibdata1,这个文件存储了所有InnoDB表的数据与索引。

  1. 如果foo是InnoDB,执行如下命令

mysql>optimeze table foo;

会返回如图信息,最后的一条Table does not support optimize, doing recreate + analyze instead,即代表optimize无法优化表。

这个时候使用如下命令优化表

mysql>alter table foo ENGINE = 'InnoDB';

mysql>analyze table foo;

返回如下信息

                         

+------------------------+---------+----------+----------+

| Table                  | Op      | Msg_type | Msg_text |

+------------------------+---------+----------+----------+

| test.foo | analyze | status   | OK       |

+------------------------+---------+----------+----------+

即可优化该表

如果开启了独享表空间,即每张表都有ibdfile。这个时候如果删除了大量的行,索引会重组并且会释放相应的空间因此不必优化

  1. 由于共享表空间所有表的数据与索引都存放于ibddata1文件中,随着数据量的增长会导致该文件越来越大。超过10G的时候查询速度就非常慢,因此在编译的时候最好开启独享表空间。因为mysql默认是关闭了独享表空间,下面有两个解决方案
  2. 方案一:先逻辑备份所有的数据库,将配置文件中innodb_file_per_table参数=1,再将备份导入
  3. 方案二:只要修改innodb_file_per_table参数,然后将需要修改的所有innodb的表都运行一遍 alter table table_name engine=innodb;即可使用第二种方式修改后,原来库中的表中的数据会继续存放于ibdata1中,新建的表才会使用独立表空间

 

转~互联网

文章来源:

地址:

转载地址:http://wcqlx.baihongyu.com/

你可能感兴趣的文章
增强版字典DictionaryEx
查看>>
ASP.NET页面刷新的实现方法总结
查看>>
夏梦竹谈Hive vs. HBase的区别
查看>>
Ignite用户配置管理介绍
查看>>
PHP精选数组函数
查看>>
用Fine Uploader+ASP.NET MVC实现ajax文件上传[代码示例]
查看>>
Java工具类
查看>>
JS地毯式学习二
查看>>
Struts2学习笔记1
查看>>
自定义String类,并且实现在STL容器中添加自定义的类型
查看>>
GreenDAO - primary key on multiple columns
查看>>
SVN 中trunk、tags、branches使用
查看>>
【BZOJ】1631: [Usaco2007 Feb]Cow Party(dijkstra)
查看>>
Zabbix监控系统深度实践
查看>>
Windows8.1和Ubuntu14.04双系统卸载Ubuntu參考教程[图]
查看>>
EF架构~XMLRepository仓储的实现~续(XAttribute方式)
查看>>
linux常用命令汇总
查看>>
Transistor latch improves on/off circuitry
查看>>
spark-sql启动后在监控页面中显示的Application Name为SparkSQL::xxxx的疑问
查看>>
Senparc.Weixin.MP SDK 微信公众平台开发教程(十四):请求消息去重
查看>>