今天对myiam数据表进行批量删除后,发现空间没有回收,查了资料后,发现要通过optimize table来回收空间 测试如下,建立数据表: CREATE TABLE `ttext` ( `id` int(11) DEFAULT NULL, `context` text ) ENGINE=MyISAM DEFAULT CHARSET=latin1 insert into tt
今天对myiam数据表进行批量删除后,发现空间没有回收,查了资料后,发现要通过optimize table来回收空间
测试如下,建立数据表:
CREATE TABLE `ttext` (
`id` int(11) DEFAULT NULL,
`context` text
) ENGINE=MyISAM DEFAULT CHARSET=latin1
insert into ttext values( 1,’tiger1′),(2,’tiger2′),(3,’tiger3′);
然后重复执行insert into ttext select * from ttext;这样重复灌数据,很快数据文件就达到240MB,这个时候,可以确认的是id为1的数据占据了1/3的空间,那么接下来,可以删除delete from ttext where id=1;
按正常的想法,这样的操作后,空间应该有回收的,但是事实没有。
OPTIMIZE TABLE should be used if you have deleted a large part of a
table or if you have made many changes to a table with variable-length
rows (tables that have VARCHAR, VARBINARY, BLOB, or TEXT columns).
You can use OPTIMIZE TABLE to
reclaim the unused space and to defragment the data file.
通过资料来看可以通过optimize table ttext来回收相应的空间。
51shop 由 PHP 语言开发, 使用快速的 MySQL 数据库保存数据 ,为中小型网站实现网上电子商务提供一个完美的解决方案.一、用户模块1. 用户注册:用户信息包括:用户ID、用户名、用户密码、性别、邮箱、省份、城市、 联系电话等信息,用户注册后不能立即使用,需由管理员激活账号,才可使用(此功能管理员可设置)2. 登录功能3. 资料修改:用户可修改除账号以后的所有资料4. 忘记密码:要求用
0
继续查看了官方手册后发现,这个操作与表所用的引擎有很大的关系。
innodb表必须是使用独立表空间的才行,其次在mysql5.1.27开始optimize table?is also supported for partitioned tables.就是可以对分区表进行优化。
针对myisam引擎,使用optimize table 还有如下功能:
注意在optimize table时会锁定表。
原文地址:mysql中optimize table使用, 感谢原作者分享。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号