1月阅读周·MySQL数据库入门:数据备份与还原之数据的还原篇

举报
叶一一 发表于 2025/01/24 11:46:46 2025/01/24
【摘要】 背景去年下半年,我在微信书架里加入了许多技术书籍,各种类别的都有,断断续续的读了一部分。没有计划的阅读,收效甚微。新年伊始,我准备尝试一下其他方式,比如阅读周。每月抽出1~2个非连续周,完整阅读一本书籍。这个“玩法”虽然常见且板正,但是有效,已经坚持阅读十二个月。已读完书籍:《架构简洁之道》、《深入浅出的Node.js》、《你不知道的JavaScript(上卷)》、《你不知道的JavaScr...

背景

去年下半年,我在微信书架里加入了许多技术书籍,各种类别的都有,断断续续的读了一部分。

没有计划的阅读,收效甚微。

新年伊始,我准备尝试一下其他方式,比如阅读周。每月抽出1~2个非连续周,完整阅读一本书籍。

这个“玩法”虽然常见且板正,但是有效,已经坚持阅读十二个月。

已读完书籍《架构简洁之道》、《深入浅出的Node.js》、《你不知道的JavaScript(上卷)》、《你不知道的JavaScript(中卷)》、《你不知道的JavaScript(下卷)》、《数据结构与算法JavaScript描述》、《WebKit技术内幕》、《前端架构:从入门到微前端》、《秒懂算法:用常识解读数据结构与算法》、《JavaScript权威指南》、《JavaScript异步编程设计快速响应的网络应用》、《编写可测试的JavaScript代码

当前阅读周书籍MySQL数据库入门

数据的还原

当数据库中的数据遭到破坏时,可以通过备份好的数据文件进行还原,这里所说的还原是指还原数据库中的数据,而库是不能被还原的。通过前面的讲解可知,备份文件实际上就是由多个CREATE、INSERT和DROP语句组成,因此只要使用mysql命令执行这些语句就可以将数据还原。

mysql命令还原数据的语法格式如下:

mysql -uusername -ppassword [dbname] <filename.sql

上述语法格式中,username表示登录的用户名,password表示用户的密码,dbname表示要还原的数据库名称,如果使用mysqldump命令备份的filename.sql文件中包含创建数据库的语句,则不需要指定数据库。

我们知道数据库中的库是不能被还原的,因此在还原数据之前必须先创建数据库。接下来通过一个案例来学习数据的还原,具体操作步骤如下。

1.删除数据库

为了演示数据的还原,首先需要使用DROP语句将数据库chapter08删除,具体语句如下:

DROP DATABASE chapter08;

上述语句执行成功后,可以使用SHOW DATABASES语句查询数据库,查询结果如下:

mysql>SHOW DATABASES;
+--------------------+
| Database             |
+--------------------+
| information_schema |
| chapter04            |
| mysql                 |
| performance_schema |
| test                  |
+--------------------+
5 rows in set (0.00 sec)

从查询结果可以看出,数据库chapter08被成功删除了。

2.创建数据库

由于库是不能被还原的,因此先要创建一个数据库chapter08,具体语句如下:

CREATE DATABASE chapter08;

上述语句执行成功后,接下来就可以还原数据库中的数据了。

3.还原数据

使用mysql语句还原C:/backup目录下的chapter08_20140305.sql文件,具体语句如下:

mysql -uroot -pitcast chapter08 <C:/backup/chapter08_20140305.sql

上述语句执行成功后,数据库中的数据就会被还原。

4.查看数据

为了验证数据已经还原成功,可以使用SELECT语句查询chapter08中的数据,查询结果如下:

mysql>SELECT * FROM student;
+----+------+------+
| id | name | age  |
+----+------+------+
|  1 | Tom   |   20 |
|  2 | Jack  |   16 |
|  3 | Lucy  |   18 |
+----+------+------+
3 rows in set (0.16 sec)

从上述查询结果可以发现,数据已经被还原了。这种还原方式只是其中的一种,还可以登录到MySQL数据库,使用source命令来还原数据,source命令还原数据的语法格式如下:

source filename.sql

source命令的语法格式比较简单,只需要指定导入文件的名称以及路径即可。按照上面的方式同样可以查看到还原后的效果,在此就不演示了,有兴趣的读者可以自己测试。

总结

在操作数据库时,难免会发生一些意外造成数据丢失。例如,突然停电、管理员的操作失误都可能导致数据的丢失。为了确保数据的安全,需要定期对数据库进行备份,这样,当遇到数据库中数据丢失或者出错的情况,就可以将数据进行还原,从而最大限度地降低损失。

当数据库中的数据遭到破坏时,可以通过备份好的数据文件进行还原,这里所说的还原是指还原数据库中的数据,而库是不能被还原的。通过前面的讲解可知,备份文件实际上就是由多个CREATE、INSERT和DROP语句组成,因此只要使用mysql命令执行这些语句就可以将数据还原。


作者介绍
非职业「传道授业解惑」的开发者叶一一。
《趣学前端》、《CSS畅想》等系列作者。华夏美食、国漫、古风重度爱好者,刑侦、无限流小说初级玩家。
如果看完文章有所收获,欢迎点赞👍 | 收藏️ | 留言📝

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。