MySQL 数据备份与恢复

这篇具有很好参考价值的文章主要介绍了MySQL 数据备份与恢复。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本次使用的MySQL版本为8.0.20

目录

一、数据备份

1.使用 MySQLdump 命令备份

(1)使用MySQLdump备份单个数据库中的所有表

案例:完成数据插入后,输入备份命令如下:

(2)使用MySQLdump备份数据库中的某个表

案例:备份booksDB数据库中的books表,输入语句如下:

(3)使用MySQLdump备份多个数据库

案例:使用MySQLdump备份booksDB和test_db数据库,输入语句如下:

二、数据恢复

1.使用MySQL命令恢复

案例:使用MySQL命令将C:\backup\booksdb_20190301.sql文件中的备份导入到数据库中,输入语句如下:

案例:使用root用户登录到服务器,然后使用source导入本地的备份文件bookdb_20221016.sql,输入语句如下:

三、表的导出和导入

1.使用MySQLdump命令导出文本文件

案例:使用MySQLdump将test_db数据库person表中的记录导出到文本文件,执行的命令如下: 

案例:使用MySQLdump命令将test_db数据库person表中的记录导出到文本文件,使用FIELDS选项,要求字段之间使用逗号“,”间隔,所有字符类型字段值用双引号括起来,定义转义字符为问号“?”,每行记录以回车换行符“\r\n”结尾,执行的命令如下: 

2.使用MySQLimport命令导入文本文件

案例:使用MySQLimport命令将D盘目录下的person.txt文件内容导入到test_db数据库中,字段之间使用逗号“,”间隔,字符类型字段值用双引号括起来,将转义字符定义为问号“?”,每行记录以回车换行符“\r\n”结尾,执行的命令如下: 


一、数据备份

1.使用 MySQLdump 命令备份

        MySQLdump 是 MySQL 提供的一个非常有用的数据库备份工具。MySQLdump 命令执行时,可以将数据库备份成一个文本文件,该文件中实际包含了多个 CREATE 和 INSERT 语句,使用这些语句可以重新创建表和插入数据。

        MySQLdump 备份数据库语句的基本语法格式如下:

mysqldump -u user -h host -ppassword dbname[tbname, [tbname...]] > filename.sql

        user表示用户名称;host表示登录用户的主机名称;password为登录密码;dbname为需要备 份的数据库名称;tbname为dbname数据库中需要备份的数据表,可以指定多个需要备份的表;右 箭头符号“>”告诉MySQLdump将备份数据表的定义和数据写入备份文件;filename.sql为备份文件的名称。

(1)使用MySQLdump备份单个数据库中的所有表

        为了更好地理解MySQLdump工具是如何工作的,这里给出一个完整的数据库例子。首先登录MySQL,按下面数据库结构创建booksDB数据库和各个表,并插入数据记录。数据库和表定义如下:

[root@client01 home]# mysql -uroot -p123456

CREATE DATABASE booksDB;
use booksDB;

CREATE TABLE books
(
    bk_id INT NOT NULL PRIMARY KEY,
    bk_title VARCHAR(50) NOT NULL,
    copyright YEAR NOT NULL
);

INSERT INTO books
VALUES (11078, 'Learning MySQL', 2010),
(11033, 'Study Html', 2011),
(11035, 'How to use php', 2003),
(11072, 'Teach yourself javascript', 2005),
(11028,'Learning C++', 2005),
(11069, 'MySQL professional', 2009),
(11026, 'Guide to MySQL 8.0', 2008),
(11041, 'Inside VC++', 2011);

CREATE TABLE authors
(
    auth_id INT NOT NULL PRIMARY KEY,
    auth_name VARCHAR(20),
    auth_gender CHAR(1)
);

INSERT INTO authors
VALUES (1001,'WriterX','f'),
(1002,'WriterA','f'),
(1003,'WriterB','m'),
(1004,'WriterC','f'),
(1011,'WriterD','f'),
(1012,'WriterE' ,'m'),
(1013,'WriterF','m'),
(1014,'WriterG' ,'f'),
(1015,'WriterH','f');

CREATE TABLE authorbook
(
    auth_id INT NOT NULL,
    bk_id INT NOT NULL,
    PRIMARY KEY (auth_id, bk_id),
    FOREIGN KEY (auth_id) REFERENCES authors (auth_id),
    FOREIGN KEY (bk_id) REFERENCES books (bk_id)
);

INSERT INTO authorbook
VALUES (1001, 11033), (1002, 11035), (1003, 11072), (1004, 11028),
(1011, 11078), (1012, 11026),(1012, 11041), (1014, 11069);

exit
  • 案例:完成数据插入后,输入备份命令如下:

# 要保证 mysql_back 目录存在才可执行
[root@client01 home]# mysqldump -u root -p booksDB > /home/mysql_back/bookdb_20221016.sql
Enter password: 

[root@client01 home]# ls /home/mysql_back/
bookdb_20221016.sql

        输入密码之后,MySQL便对数据库进行了备份,在/home/mysql_back文件夹下面查看刚才备份过的文件,使用VS Code 打开文件可以看到,备份文件包含了一些信息,文件开头首先表明了备份文件使用的MySQLdump工具的版本号;然后是备份账户的名称和主机信息,以及备份的数据库的名称,最后是MySQL服务器的版本号,在这里为8.0.20。

        备份文件接下来的部分是一些SET语句,这些语句将一些系统变量值赋给用户定义变量,以确保被恢复的数据库的系统变量和原来备份时的变量相同,例如:

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

        该SET语句将当前系统变量character_set_client的值赋给用户定义变量@old_character_ set_client。其他变量与此类似。

        备份文件中以“--”字符开头的行为注释语句;以“/*!”开头、“*/”结尾的语句为可执行的MySQL注释,这些语句可以被MySQL执行,但在其他数据库管理系统中将被作为注释忽略,以提高数据库的可移植性。另外,备份文件开始的一些语句以数字开头,代表的是MySQL版本号,这些语句只有在指定的MySQL版本或者比该版本高的情况下才能执行。例如,40101,表明这些语句只有在MySQL版本号为4.01.01或者更高的条件下才可以被执行。

(2)使用MySQLdump备份数据库中的某个表

其语法格式为:

mysqldump –u user –h host –p dbname [tbname, [tbname...]] > filename.sql

        tbname表示数据库中的表名,多个表名之间用空格隔开。备份表和备份数据库中所有表的语句中不同的地方在于,要在数据库名称dbname之后指定需要备份的表名称。

  • 案例:备份booksDB数据库中的books表,输入语句如下:

[root@client01 mysql_back]# mysqldump -u root -p booksDB books > /home/mysql_back/books_20221017.sql
Enter password: 

[root@client01 mysql_back]# ls
bookdb_20221016.sql  books_20221017.sql

(3)使用MySQLdump备份多个数据库

        如果要使用MySQLdump备份多个数据库,就需要使用--databases参数。备份多个数据库的语句格式如下:

mysqldump –u user –h host –p --databases [dbname, [dbname...]] > filename.sql

        使用--databases参数之后,必须指定至少一个数据库的名称,多个数据库名称之间用空格隔开。

  • 案例:使用MySQLdump备份booksDB和test_db数据库,输入语句如下:

mysqldump -u root -p --databases booksDB test_db > /home/mysql_back/booksdb_test_db_20221017

另外,使用--all-databases参数可以备份系统中所有的数据库,语句如下:

mysqldump -u root -p --all-databases > /home/mysql_back/alldbinMySQL.sql

 使用参数--all-databases时,不需要指定数据库名称。

二、数据恢复

1.使用MySQL命令恢复

        对于已经备份的包含CREATE、INSERT语句的文本文件,可以使用MySQL命令导入到数据库中。本此使用MySQL命令导入sql文件的方法。

        备份的sql文件中包含CREATE、INSERT语句(有时也会有DROP语句)。MySQL命令可以直接执行文件中的这些语句。其语法如下:

mysql –u user –p [dbname] < filename.sql

        user是执行backup.sql中语句的用户名;-p表示输入用户密码;dbname是数据库名。如果filename.sql文件为MySQLdump工具创建的包含创建数据库语句的文件,执行的时候不需要指定数据库名。

  • 案例:使用MySQL命令将C:\backup\booksdb_20190301.sql文件中的备份导入到数据库中,输入语句如下:

mysql –u root –p booksDB < /home/mysql_back/bookdb_20221016.sql

        执行该语句前,必须先在MySQL服务器中创建booksDB数据库,如果不存在恢复过程将会出错。命令执行成功之后bookdb_20221016.sql文件中的语句就会在指定的数据库中恢复以前的表。

如果已经登录连接MySQL服务器,还可以使用source命令导入sql文件。source语句语法如下:

source filename
  • 案例:使用root用户登录到服务器,然后使用source导入本地的备份文件bookdb_20221016.sql,输入语句如下:

--选择要恢复到的数据库
mysql> use booksDB;
Database changed

--使用source命令导入备份文件
mysql> source /home/mysql_back/bookdb_20221016.sql

        命令执行后,会列出备份文件bookdb_20221016.sql中每一条语句的执行结果。source命令执行成功后,bookdb_20221016.sql中的语句会全部导入到现有数据库中。

执行source命令前,必须使用use语句选择数据库。不然,恢复过程中会出现“ERROR 1046 (3D000): No database selected”的错误。

三、表的导出和导入

1.使用MySQLdump命令导出文本文件

        前面介绍了使用MySQLdump备份数据库,该工具不仅可以将数据导出为包含CREATE、INSERT的sql文件,也可以导出为纯文本文件。MySQLdump创建一个包含创建表的CREATE TABLE语句的tablename.sql文件和一个包含其数据的tablename.txt文件。MySQLdump导出文本文件的基本语法格式如下:

mysqldump -T path -u root -p dbname [tables] [OPTIONS]

--OPTIONS选项
--fields-terminated-by=value
--fields-enclosed-by=value
--fields-optionally-enclosed-by=value
--fields-escaped-by=value
--lines-terminated-by=value

        只有指定了-T参数才可以导出纯文本文件;path表示导出数据的目录;tables为指定要导出的表名称,如果不指定,将导出数据库dbname中所有的表;[OPTIONS]为可选参数选项,这些选项需要结合-T选项使用。

使用OPTIONS常见的取值有:

  • --fields-terminated-by=value:设置字段之间的分隔字符,可以为单个或多个字符,默认情况下为制表符“\t”。
  • --fields-enclosed-by=value:设置字段的包围字符。
  • --fields-optionally-enclosed-by=value:设置字段的包围字符,只能为单个字符,只能包括CHAR和VERCHAR等字符数据字段。
  • --fields-escaped-by=value:控制如何写入或读取特殊字符,只能为单个字符,即设置转义字符,默认值为反斜线“\”。
  • --lines-terminated-by=value:设置每行数据结尾的字符,可以为单个或多个字符,默认值为“\n”。
  • 案例:使用MySQLdump将test_db数据库person表中的记录导出到文本文件,执行的命令如下: 

mysqldump -T /home/mysql_back test_db person -u root -p

        语句执行成功,/home/mysql_back/目录下面将会有两个文件,分别为person.sql和person.txt。person.sql包含创建person表的CREATE语句;person.txt包含数据包中的数据,其内容如下:

MySQL 数据备份与恢复

  • 案例:使用MySQLdump命令将test_db数据库person表中的记录导出到文本文件,使用FIELDS选项,要求字段之间使用逗号“,”间隔,所有字符类型字段值用双引号括起来,定义转义字符为问号“?”,每行记录以回车换行符“\r\n”结尾,执行的命令如下: 

mysqldump -T /home/mysql_back test_db person -u root -p --fields-terminated-by=, --fields-optionally-enclosed-by=\" --fields-escaped-by=? --lines-terminated-by=\r\n
Enter password:******

        上面语句要在一行中输入,语句执行成功,/home/backup/目录下面将会有两个文件,分别为person.sql和person.txt。person.sql包含创建person表的CREATE语句,其内容与前面例子中的相同,person.txt文件的内容与上一个例子不同,显示如下:

  1,"Green",21,"Lawyer"
  2,"Suse",22,"dancer"
  3,"Mary",24,"Musician"
  4,"Willam",20,"sports man"
  5,"Laura",25,?N
  6,"Evans",27,"secretary"
  7,"Dale",22,"cook"
  8,"Edison",28,"singer"
  9,"Harry",21,"magician"
  10,"Harriet",19,"pianist"

        可以看到,只有字符类型的值被双引号括了起来,而数值类型的值没有;第5行记录中的NULL值表示为“?N”,使用问号“?”替代了系统默认的反斜线转义字符“\”。

2.使用MySQLimport命令导入文本文件

        使用MySQLimport可以导入文本文件,并且不需要登录MySQL客户端。使用MySQLimport语句需要指定所需的选项、导入的数据库名称以及导入的数据文件的路径和名称。MySQLimport命令的基本语法格式如下:

mysqlimport -u root-p dbname filename.txt [OPTIONS]

--OPTIONS选项
--fields-terminated-by=value
--fields-enclosed-by=value
--fields-optionally-enclosed-by=value
--fields-escaped-by=value
--lines-terminated-by=value
--ignore-lines=n

        dbname为导入的表所在的数据库名称。注意,MySQLimport命令不指定导入数据库的表名称,数据表的名称由导入文件名称确定,即文件名作为表名,导入数据之前该表必须存在。

[OPTIONS]为可选参数选项,其常见的取值有:

  •  --fields-terminated-by= 'value':设置字段之间的分隔字符,可以为单个或多个字符,默认情况下为制表符“\t”。
  •  --fields-enclosed-by= 'value':设置字段的包围字符。
  •  --fields-optionally-enclosed-by= 'value':设置字段的包围字符,只能为单个字符,包括CHAR和VERCHAR等字符数据字段。
  •  --fields-escaped-by= 'value':控制如何写入或读取特殊字符,只能为单个字符,即设置转义字符,默认值为反斜线“\”。
  •  --lines-terminated-by= 'value':设置每行数据结尾的字符,可以为单个或多个字符,默认值为“\n”。
  •  --ignore-lines=n:忽视数据文件的前n行。
  • 案例:使用MySQLimport命令将D盘目录下的person.txt文件内容导入到test_db数据库中,字段之间使用逗号“,”间隔,字符类型字段值用双引号括起来,将转义字符定义为问号“?”,每行记录以回车换行符“\r\n”结尾,执行的命令如下: 

mysqlimport -u root -p test_db /home/mysql_back/person.txt --fields-terminated-by=, --fields-optionally-enclosed-by=\" --fields-escaped-by=? --lines-terminated-by=\r\n

上面的语句要在一行中输入,语句执行成功,将把person.txt中的数据导入到数据库。文章来源地址https://www.toymoban.com/news/detail-515330.html

到了这里,关于MySQL 数据备份与恢复的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何备份与恢复MySQL数据库数据

    目录 一、MySQL备份 备份方式 完全备份 差异备份 增量备份 二、常见的备份方法 物理冷备 专用备份工具 mysqldump 或 mysqlhotcopy 启用二进制日志进行增量备份 第三方工具备份 三、MySQL完全备份 四、数据库完全备份分类 物理冷备份与恢复 mysqldump备份与恢复 五、物理冷备份与恢复

    2024年02月16日
    浏览(23)
  • mysql 数据备份与恢复使用详解

    对一个运行中的线上系统来说,定期对数据库进行备份是非常重要的,备份不仅可以确保数据的局部完整性,一定程度上也为数据安全性提供了保障,设想如果某种极端的场景下,比如磁盘损坏导致某个时间段数据丢失,或者误操作导致数据表数据被删等... 这种情况在现实中

    2024年02月08日
    浏览(22)
  • 9-MySQL数据库 数据的备份与恢复

    1.date文件的备份 2.mysqldump 备份 说明: mysqldump是MySQL数据库中的一个实用程序,它主要用于转储(备份)数据库。mysqldump通过生成一个SQL脚本文件,包含从头开始重新创建数据库所必需的(如 CREATE TABLE和INSERT等),来实现数据库的备份和转储。这样,你可以在任何时候通过运

    2024年02月08日
    浏览(25)
  • mysql数据库备份和恢复

    数据备份可以分为三种, 热备份。 数据库处于运行状态,此时依赖数据库的日志文件进行备份 温备份。 进行数据备份时数据库服务正常进行,但是数据智能度不能写。 冷备份。数据库处于关闭状态,能够够好的保证数据库的完整性。 逻辑备份。使用软件从数据库中提取数

    2024年02月12日
    浏览(25)
  • MySQL数据库备份与恢复

    在项目的开发过程中数据库的备份是非常重要的,为了防止数据库受到破坏,造成不可估量的损失,所以一定要进行数据库的备份,并且需要掌握数据库恢复方法,在发生数据库损坏的时候,能快速进行数据库恢复。 本文主要介绍MySQL数据表备份与恢复主要的三种方法,包括

    2024年02月12日
    浏览(24)
  • Mysql数据备份与恢复——Docker版

    ​ 工作上由于需要将旧服务器停用换用新服务器,而旧服务器上存放的mysql数据库,查看磁盘得知大概50G以上,如果采用工具将数据导出成json再到新服务上执行,其过程花费时间太长了,至少得半天… 所以想着能否直接将数据库上的data目录数据直接复制到新的服务器上,然

    2023年04月27日
    浏览(17)
  • MySQL数据库的备份与恢复

    备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。 造成数据丢失的原因: 程序错误 人为操作错误 运算错误 磁盘故障 灾难(如火灾、地震)和盗窃 1)物理备份 物理备份:对数据库操作系统的物理文件(如数据

    2024年02月04日
    浏览(20)
  • Mysql数据库增量备份与恢复

    使用 mysqldump 进行完全备份,备份的数据中有重复数据,备份时间与恢复时间长。 而增量备份就是备份自上一次备份之后增加或改变的文件或内容。 1、增量备份的特点: 没有重复数据,备份量不大,时间短 恢复麻烦:需要上次完全备份及完全备份之后所有的增量备份才能恢复

    2024年02月07日
    浏览(38)
  • 数据库(MySQL的备份和恢复)

    目录 1.1 MySQL 日志管理 1.1.1 MySQL日志类型 1.1.2 错误日志 错误日志中主要记录的几种日志 错误日志的定义 1.1.3 通用查询日志 1.1.4 慢查询日志 和慢查询相关的变量设置 1.1.5 二进制日志 二进制日志是记录执行的语句还是执行后的数据 日志滚动  1.2 MySQL备份 1.2.1 备份类型 1.2.2

    2024年01月25日
    浏览(21)
  • 【数据库四】MySQL备份与恢复

    数据库备份 物理备份 :直接对数据库的 数据文件或者日志文件 进行备份. 逻辑备份 :对 数据库的库或表对象 进行备份. 备份策略 完全备份 :每次备份 都备份完整的数据库 . 是对整个数据库、数据库结构和文件结构的备份。 保存的是 备份完成时刻的数据库 。 是 差异备份与增

    2024年02月11日
    浏览(21)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包