解析mysql 表中的碎片产生原因以及清理
发布时间:2020-12-13 06:25:57 所属栏目:PHP教程 来源:网络整理
导读:大量删除数据必然会在数据文件中造成不连续的空白空间,而当插入数据时,这些空白空间则会被利用起来 。 对于不同的存储引擎整理碎片的方式不一样。 可以有以下方式: show table status from test like 'testusers'G *************************** 1. row *
大量删除数据必然会在数据文件中造成不连续的空白空间,而当插入数据时,这些空白空间则会被利用起来 。 show table status from test like 'testusers'G *************************** 1. row *************************** .... Rows: 3 Avg_row_length: 45 Data_free: 40 ..... 因为在中间删除,所以留下了空白 optimize table testusers; +----------------+----------+----------+----------+ | Table | Op | Msg_type | Msg_text | +----------------+----------+----------+----------+ | test.testusers | optimize | status | OK | +----------------+----------+----------+----------+ mysql> show table status from test like 'testusers'G *************************** 1. row *************************** ... Rows: 3 Avg_row_length: 32 Data_length: 96 Data_free: 0 1 row in set (0.00 sec) 在optimize后,Data_free已经变为0.碎片数据被清除。 同样还可以用以下方式,效果和optimize一样 对于innodb 使用optimize和mysqlcheck都不起作用,可以如下进行 对于小表的话直接用ALTER TABLE table_name ;回收表空间,对于大表就不能直接采用这种方式,因为会造成长时间的锁表。可以采用新建表转移数据,然后删除旧表的形式,然后再重命名表。 另外有个python可以查看innodb表空间信息,可以在网上找哈,用python写的。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |