博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
optimize table tablename
阅读量:6653 次
发布时间:2019-06-25

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

optimize 优化表

OPTIMIZE 命令支持的引擎MyIsam, InnoDB, ARCHVE
当对表有大量的增删改操作时,需要用optimize对表进行优化,可以减少空间与提高I/O性能,
命令optimize table tablename;

1.假如有session表且存储引擎为MyISAM

mysql> OPTIMIZE TABLE session;
+--------------+----------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+--------------+----------+----------+----------+
| test.session | optimize | status | OK |
+--------------+----------+----------+----------+
1 row in set
2.如果是InnoDB引擎
首先查看innodb_file_per_table(是否独享表空间)。
mysql> show variables like 'innodb_file_per_table';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| innodb_file_per_table | ON |
+-----------------------+-------+
1 row in set
on表示打开了
OFF代表开启共享表空间没有打开
即采用的是默认的共享表空间
这个时候可以在mysql的datadir路径下看到一个非常大的文件ibdata1,
这个文件存储了所有InnoDB表的数据与索引
如果开启了独享表空间,即每张表都有ibdfile,这个时候如果删除了大量的行,索引会重组并且会释放相应的空间因此不必优化
由于共享表空间所有表的数据与索引都存放于ibddata1文件中
随着数据量的增长会导致该文件越来越大,超过10G的时候查询速度就非常慢,因此在编译的时候最好开启独享表空间,因为mysql默认是关闭了独享表空间
下面有两个解决方案
方案一:先逻辑备份所有的数据库,将配置文件中innodb_file_per_table参数=1,再将备份导入
方案二:只要修改innodb_file_per_table参数,然后将需要修改的所有innodb的表都运行一遍
alter table table_name engine=innodb;
即可使用第二种方式修改后,原来库中的表中的数据会继续存放于ibdata1中,
新建的表才会使用独立表空间

stu是innodb

mysql> OPTIMIZE TABLE stu;
+----------+----------+----------+-------------------------------------------------------------------+
| Table | Op | Msg_type | Msg_text |
+----------+----------+----------+-------------------------------------------------------------------+
| test.stu | optimize | note | Table does not support optimize, doing recreate + analyze instead |
| test.stu | optimize | status | OK |
+----------+----------+----------+-------------------------------------------------------------------+
2 rows in set
这时需要
mysql> alter table stu engine='innodb';
Query OK, 0 rows affected
Records: 0 Duplicates: 0 Warnings: 0

mysql> analyze table stu;

+----------+---------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+----------+---------+----------+----------+
| test.stu | analyze | status | OK |
+----------+---------+----------+----------+
1 row in set
来优化表

转载于:https://www.cnblogs.com/HKUI/p/5453502.html

你可能感兴趣的文章
11.14-11.18周总结(二)
查看>>
一些总结
查看>>
软件测试工程师必备技能,纯干货分享!
查看>>
国外一个牛人写好的VIM配置方案spf13
查看>>
Python 单向循环链表
查看>>
Redis 客户端安装与远程连接图解
查看>>
BZOJ3328: PYXFIB(单位根反演?)
查看>>
使用EasyUI的treegrid犯的个低级错误
查看>>
jmeter 登录并发 (此文章有待修改)
查看>>
spring事务测试2,为了解决spring事务测试1
查看>>
扩展卡特兰数
查看>>
ajax对象。同步与异步及ajax发送请求
查看>>
event.stopPropagation 阻止触发父元素的绑定事件
查看>>
[开源] KJFramework.Message 智能二进制消息框架
查看>>
appcan本地数据库,uexDataBaseMgr插件
查看>>
HTML学习笔记一基本标签
查看>>
Mac、nvm、node/npm
查看>>
【转载】随机函数rand()
查看>>
二分查找 BestCoder Round #36 ($) Gunner
查看>>
PowerShell【Do While、Do Until篇】
查看>>