如果想看更多有关于MySQL数据库的文章,请跳转到MySQL自学目录
本节简单地讲述用mysqldump来进行备份和恢复
备份
对于数据库的备份,我们用第三方工具,也可以MySQL自带的工具。这里我们就用MySQL自带的工具–mysqldump来为大家讲解如何进行备份。
mysqldump可以导出库和表。导出的形式是建表语句和插入语句。
对于导出库和表我们有四种方式:
- 导出库下面的指定表
mysqldump -u 用户名 -p 密码 库名 表1 表2 表n > 地址/备份文件名称 - 导出库下面的所有表
mysqldump -u 用户名 -p 密码 库名 > 地址/备份文件名称 - 导出一个库(有对库的操作语句)
mysqldump -u 用户名 -p 密码 -B 库1 库2 库n > 地址/备份文件名称 - 导出所有库
mysqldump -u 用户名 -p 密码 -A > 地址/备份文件名称
举个栗子
# 导出test2库中的porderitems和productnotes表
C:\WINDOWS\system32>mysqldump -uroot -p123456 test2 orderitems productnotes > H://orderitemsandproductnotes.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
# 弹出了一个警告,可以忽略
# 导出一个test3库
C:\WINDOWS\system32>mysqldump -uroot -p123456 test3 > H://test3.sql
# 导出test2和test3库
C:\WINDOWS\system32>mysqldump -uroot -p123456 -B test2 test3 > H://test2andtest3.sql
# 导出所有库
C:\WINDOWS\system32>mysqldump -uroot -p123456 -A > H://all.sql
恢复
当数据库中的数据出现错误或丢失后,我们需要将数据恢复。我们将备份好的数据进行恢复即可。
恢复数据有两种方式
1. 登陆到MySQL命令行
- 对于库级的备份文件
source 文件备份地址
对于表级的备份文件
use 库名(到某个数据库下面)
source 文件备份地址
2. 不登录到MySQL命令行
- 对于库级的备份文件
mysql -u 用户名 -p 密码 < 库级备份文件地址
对于表级的备份文件
mysql -u 用户名 -p 密码 库名 < 库级备份文件地址
举个栗子
# 登陆到MySQL
# 恢复test2库中的porderitems和productnotes表
mysql> use test2;
mysql> source H://orderitemsandproductnotes.sql
# 恢复test3和test2库
mysql> source H://test2andtest3.sql
# 不登陆到MySQL
# 恢复test2库中的porderitems和productnotes表
C:\WINDOWS\system32>mysql -uroot -p123456 test2 < H://orderitemsandproductnotes.sql
# 恢复test3和test2库
C:\WINDOWS\system32>mysql -uroot -p123456 < H://test2andtest3.sql
tips
- 注意执行操作时没有加分号;