原来电脑上安装的mysql是5.5版本的,5.5版本有一个缺陷,一张表中只能有一个字段值设置为当前时间,如果一段SQL同时为创建时间和修改时间的字段赋值为当前时间,执行就会报错。于是决定将mysql升级到5.7版本。

升级之前先将原来的数据文件备份出来,查询数据文件的存储位置:

show global variables like "%datadir%";

mysql 还原数据库缓慢 mysql还原数据库报错_sql

打开如上图所示的文件夹,可以看到里边有很多数据库,一个文件夹代表一个数据库

mysql 还原数据库缓慢 mysql还原数据库报错_数据_02

等到新的数据库安装完成以后,将data里边除了mysql文件夹以外所有数据拷贝到新数据库的data目录下,重新启动mysql,启动好以后,连接上数据库,就会发现已经有了原先的数据库。这里需要注意的是,如果少了上图红色箭头所指的ibdata1文件,查询表的时候会报表不存在的错误。

ibdata1小知识:

 ibdata1即Innodb data1的缩写,是innodb引擎的表空间,用于存放以下内容:

数据字典Data dictionary:  只读的表,存储对象的相关信息,如占用空间,列的缺省值,约束信息,用户名,权限,审计信息等;
双写缓冲区 Double write buffer:; Innodb写入数据默认是16k/pages为一个单位写入,而磁盘是4k/page一个单位,为了防止写入一半,断电无法恢复数据的情况发生,引入了double writer buffer机制;double write buffer是一段连续空间,大小2M(128 page),数据写入的时候先写到doublewrite空间,然后再写入到磁盘,如果发生写入了一个page一半的时候断电,恢复后会自动从doublewrite中恢复;
插入缓冲区INSERT BUFFER:针对辅助索引(非unique),插入数据的时候,先将插入的数据在buffer中根据辅助索引叶子节点的Page_no排序,而后按照Page_no分批次插入,提高性能;
回滚日志rollback segment: 用于存储未提交事物,便于用户rollback,当commit后,数据即被标记无效;
undo空间 用于存放undo 日志的;用于记录事物变更前的状态,如果未commit,其他session可以查看到变更前状态
如果innodb_file_per_table=0,则Innodb的数据和索引也存储在ibdata中; (如果为1,则存储在表名相同的ibd和frm文件中); 如果表数据存储在ibdata中的话,那么删除表是不会释放空间;