1、根据官网文档的解释,在正常关闭或初始化中止时,将删除临时表空间,并在每次启动服务器时重新创建,重启能够释放空间的原因在于正常关闭数据库,临时表空间就被删除了,重新启动后重新创建,也就是重启引发了临时表空间的重建,重新初始化,所以,重建后的大小为12M。
2、对临时表空间的大小进行限制,允许自动增长,但最大容量有上限。
使用: truncate table tablename DROP STORAGE解释: 直接删除表,并且释放存储空间。truncate的意思是清空表数据, “DROP STORAGE”是释放存储空间。
1,备份数据库从命令行进入MySQL Server 5.1/bin
备份全部数据库,执行命令mysqldump -q -uusername -pyourpassword --add-drop-table --all-databases >/backup/all.sql
除数据库
drop database db1
drop database db2
此处不删除应用数据库,在全库恢复数据库时,就会报异常错误,一些表的*.ibd会报不存在。
解决方式:
movo db1 /backup/db1_bak
movo db2 /backup/db2_bak
做完此步后,然后停止数据库。
2,修改mysql配置文件
修改my.cnf文件,增加下面配置
innodb_file_per_table
对每张表使用单独的innoDB文件, 修改/etc/my.cnf文件
3,删除原数据文件
删除原来的ibdata1文件及日志文件ib_logfile*,删除data目录下的应用数据库文件夹(mysql,test,information_schema数据库本身文件夹不要删除)
4,还原数据库
启动数据库服务
从命令行进入MySQL Server 5.1/bin
还原全部数据库,执行命令mysql -uusername -pyourpassword </all.sql
大公告成。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)