永发信息网

linux下mysql的drop table命令不能把表和相关存储信息都删除干净,怎么弄

答案:4  悬赏:60  手机版
解决时间 2021-02-15 20:21
  • 提问者网友:相思似海深
  • 2021-02-14 22:10
我建立个表,在里面插入20多万数据,占用了linux很多兆,使用drop table命令时,并不能吧所有空间都还原
最佳答案
  • 五星知识达人网友:动情书生
  • 2021-02-14 22:16
使用OPTIMIZE TABLE语句可以。
OPTIMIZE TABLE语法
OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...
如果您已经删除了表的一大部分,或者如果您已经对含有可变长度行的表(含有VARCHAR, BLOB或TEXT列的表)进行了很多更改,则应使用OPTIMIZE TABLE。被删除的记录被保持在链接清单中,后续的INSERT操作会重新使用旧的记录位置。您可以使用OPTIMIZE TABLE来重新利用未使用的空间,并整理数据文件的碎片。
在多数的设置中,您根本不需要运行OPTIMIZE TABLE。即使您对可变长度的行进行了大量的更新,您也不需要经常运行,每周一次或每月一次即可,只对特定的表运行。
OPTIMIZE TABLE只对MyISAM, BDB和InnoDB表起作用。
对于MyISAM表,OPTIMIZE TABLE按如下方式操作:
1. 如果表已经删除或分解了行,则修复表。
2. 如果未对索引页进行分类,则进行分类。
3. 如果表的统计数据没有更新(并且通过对索引进行分类不能实现修复),则进行更新。
对于BDB表,OPTIMIZE TABLE目前被映射到ANALYZE TABLE上。对于InnoDB表,OPTIMIZE TABLE被映射到ALTER TABLE上,这会重建表。重建操作能更新索引统计数据并释放成簇索引中的未使用的空间。
要重新使用未使用的空间并减小文件的尺寸,则使用OPTIMIZE TABLE语句或myisamchk应用程序重新编排表。OPTIMIZE TABLE更简便,但是myisamchk速度更快。
全部回答
  • 1楼网友:行雁书
  • 2021-02-14 23:31
于在linux下的操作。
  • 2楼网友:三千妖杀
  • 2021-02-14 23:14
于在linux下的操作。
  • 3楼网友:渡鹤影
  • 2021-02-14 23:06
数据库中的内容被删除之后,空间并不会得到回收,也就是说原来占用的空间还是会被数据库占用,要向回收这些空间需要进行数据库的收缩。但是mysql好像还不支持数据库或者文件级别的收缩。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯