数据库的表内容删除以后,空间不释放,把表也drop掉以后,还是不释放,
现在我把则个数据库都删了,占用的空间还是没有释放。请大家帮帮忙给个解决办法吧。

解决方案 »

  1.   

    这个数据库的数据放在ibdata1里面。
    同时还有其他一些数据库的数据也在ibdata1里面。其他数据库正在正常使用。
      

  2.   

    没有办法,MYSQL不会自动释放这些空间。唯一的做法。1)MYSQLDUMP导出所有数据库的所有内容。
    2)停止MYSQL服务。
    3)删除IBDATA文件
    4)重启MYSQL服务,会自动创建一个新的IBDATA
    5)导入所有数据。
      

  3.   

    虽然可以通过这个方法进行,但个人并不推荐去释放这些空间。 MYSQL会自动利用这个IBDATA文件中的空闲位置。
      

  4.   


    因为他有几个不可以停止的数据库也在共用这个IBDATA文件,有分别处理的方法吗。
      

  5.   

    mysql 5 的话,可以用独立表空间的方式,这样可以释放空间。