mysql-数据备份与还原(代码片段)

旷世奇才李先生 旷世奇才李先生     2023-03-18     389

关键词:

有志者,事竟成
文章持续更新,可以微信搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。

文章目录


前言

为了保证数据的安全,需要定期对数据进行备份。备份的方式有很多种,效果也不一样。如果数据库中的数据出现了错误,就需要使用备份好的数据进行数据还原。这样可以将损失降至最低。而且,可能还会涉及到数据库之间的数据导入与导出。

一、数据备份

备份数据是数据库管理中最常用的操作。为了保证数据库中数据的去安全,数据库管理员需要定期的进行数据库备份。一旦数据库遭到破坏,即通过备份的文件来还原数据库。因此,数据备份是很重要的工作。

1、使用mysqldump命令备份

mysqldump命令可以将数据库中的数据备份成一个文本文件。表的结构和表中的数据将存储在生成的文本文件中。

mysqldump命令的工作原理很简单。它先查出需要备份的表的结构,再在文本文件中生成一个create语句。然后,将表中的所有记录转换成一条insert语句。这些create语句和insert语句都是还原时使用的。还原数据时就可以使用其中的create语句来创建表。使用其中的insert语句来还原数据。

1、备份一个数据库

使用mysqldump命令备份一个数据库的基本语法如下:

mysqldump -u username -p dbname table1 table2 ... > backupname.sql

其中,dbname参数表示数据库的名称;table1和table2参数表示表的名称,没有该参数时将备份整个数据;backupname.sql参数表示备份文件的名称,文件名前面可以加上一个绝对路径。通常将数据库备份成一个后缀名为sql的文件。

2、备份多个数据库

mysqldump命令备份多个数据库的语法如下:

mysqldump -u username -p --databases dbname1 dbname2 ... > backupname.sql

这里要加上“–databases”这个选项,然后后面跟多个数据库的名称。

3、备份所有数据库

mysqldump命令备份所有数据库的语法如下:

mysqldump -u username -p --all-databases > backupname.sql

使用“–all-databases”选项就可以备份所有的数据库了。

2、直接复制整个数据库目录

MySQL有一种最简单的备份办法,就是将MySQL中的数据库文件直接复制出来。这种方法最简单,速度也最快。使用这种方法时,最好将服务器先停止。这样,可以保证在复制期间数据库中的数据不会发生变化。如果在复制数据库的过程中还有数据写入,就会造成数据不一致。

这种方法虽然简单快速,但不是最好的备份方法。因为,实际情况可能不允许停止MySQL服务器。而且,这种方法对InnoDB存储引擎的表不适用。对于MyISAM存储引擎的表,这样备份和还原很方便。但是还原时最好是相同版本的MySQL数据库,否则可能会存在文件类型不同的情况。

3、使用mysqlhotcopy工具快速备份

如果备份时不能停止MySQL服务器,可以采用mysqlhotcopy工具。mysqlhotcopy工具的备份方式比mysqldump命令快。

mysqlhotcopy工具是一个Perl脚本,主要在Linux操作系统下使用。mysqlhotcopy工具使用lock tables、flush tables和cp来进行快速备份。其工作原理是,先将需要备份的数据库加上一个读操作锁,然后,用flush tables将内存中的数据写回到硬盘上的数据库中,最后,把需要备份的数据库文件复制到目标目录。使用mysqlhotcopy的命令如下:

mysqlhotcopy [option] dbname1 dbname2 ... backupDir/

其中,dbname1等表示需要备份的数据库的名称;backupDir参数指出备份到哪个文件夹下。这个命令的含义就是将dbname1、dbname2等数据库备份到backDir目录下。

二、数据还原

管理员的非法操作和计算机的故障都会破坏数据库文件。当数据库遭到这些意外时,可以通过备份文件将数据库还原到备份的状态。这样可以将损失降低到最小。

1、使用mysql命令还原

管理员通常使用mysqldump命令将数据库中的数据备份成一个文本文件。通常这个文件的后缀名是.sql。需要还原时,可以使用mysql命令来还原备份的数据。

备份文件中通常包含create语句和insert语句。mysql命令可以执行备份文件中的create语句和insert语句。通过create语句来创建数据库和表。通过insert语句来插入备份的数据。mysql命令的基本语法如下:

mysql -u root -p [dbname] < backup.sql

其中,dbname参数表示数据库名称。该参数是可选参数,可以指定数据库名,也可以不指定。指定数据库名时,表示还原该数据库下的表。不指定数据库名时,表示还原特定的一个数据库。而备份文件中创建数据库的语句。

下面使用root用户备份所有的数据库。命令如下:

mysql -u root -p [dbname] < backup.sql

2、直接复制到数据库目录

之前介绍过一种直接复制数据的备份方法。通过这种方式备份的数据,可以直接复制到MySQL的数据库目录下。通过这种方式还原时,必须保证两个MySQL数据库的主版本号是相同的。因为只有MySQL数据库主版本号相同时,才能保证这两个MySQL数据库的文件类型是相同的。而且,这种方式对MyISAM类型的表比较有效。对于InnoDB类型的表则不可用。因为InnoDB表的表空间不能直接复制。

三、数据库迁移

数据库迁移就是指将数据库从一个系统移动到另一个系统上。数据库迁移的原因是多种多样的。可能是因为升级了计算机,或者是部署开发的管理系统,或者升级了MySQL数据库。甚至是换用其他的数据库。根据上述情况,可以将数据库迁移大致分为3类。这3类分别是在相同版本的MySQL数据库之间迁移、迁移到其他版本的MySQL数据库中和迁移到其他类型的数据库中。

1、相同版本的MySQL数据库之间的迁移

只有数据库表都是MyISAM类型的才能使用这种方式。

最常用和最安全的方式是使用mysqldump命令来备份数据库。然后使用mysql命令将备份文件还原到新的MySQL数据库中。这里可以将备份和迁移同时进行。假设从一个名为host1的机器中备份出所有的数据库,然后,将这些数据库迁移到名为host2的机器上。命令如下:

mysqldump -h name1 -u root --password1 --all-databases | 
mysql -h host2 -u root --password=password2

其中,“|”符号表示管道,其作用是将mysqldump备份的文件送给mysql命令;“–password=password1”是name1主机上root用户的密码。同理,password2是name2主机上的root用户的密码。通过这种方式可以直接实现迁移。

2、不同版本的MySQL数据库之间的迁移

高版本的MySQL数据库通常都会兼容低版本,因此可以从低版本的MySQL数据库迁移到高版本的MySQL数据库。对于MySIAM类型的表可以直接复制,也可以使用mysqlhotcopy工具。但是InnoDB类型的表不可以使用这两种方法。最常用的办法是使用mysqldump命令来进行备份,然后,通过mysql命令将备份文件还原到目标MySQL数据库中。但是,高版本的MySQL数据库很难迁移到低版本的MySQL数据库。因为高版本的MySQL数据库可能有一些新的特性,这些特性是低版本MySQL数据库所不具有的。数据库迁移时要特别小心,最好使用mysqldump命令来进行备份,避免迁移时造成数据丢失。

四、表的导出和导入

MySQL数据库中的表可以导出成文本文件、XML文件或者HTML文件。相应的文本文件也可以导入MySQL数据库中。在数据库的日常维护中,经常需要进行表的导出和导入的操作。

1、用select…into outfile导出文本文件

MySQL中,可以使用select…into outfile语句将表的内容导出成一个文本文件。其基本语法形式如下:

select [列名] from table [where 语句] into outfile '目标文件'[option];

该语句分为两个部分。前半部分是一个普遍的select语句,通过这个select语句来查询所需要的数据;后半部分是导出数据的。其中,“目标文件”参数指出将查询的记录导出到哪个文件;“OPTION”参数是可以有常用的5个选项。

2、用mysqldump命令导出文本文件

mysqldump命令可以备份数据库中的数据。但是,备份时是在备份文件中保存了create语句和insert语句。不仅如此,mysqldump命令还可以导出文本文件。其基本的语法形式如下:

mysqldump -u root -pPassword -T 目标目录 dbname table [option];

其中,Password参数表示root用户的密码,密码紧挨着-p选项;目标目录参数是指导出的文本文件的路径;dbname参数表示数据库的名称;table参数表示表的名称;

3、用mysql命令导出文本文件

mysql命令可以用来登录MySQL服务器,也可以用来还原备份文件。同时,mysql命令也可以导出文本文件。其基本语法形式如下:

mysql -u root -pPassword -e "select 语句" dbname > C:/name.txt;

其中,Password表示root用户的密码;使用-e选项就可以执行SQL语句;“selec语句”用来查询记录。C:/name.txt表示导出文件的路径。

4、用load data infile方式导入文本文件

MySQL中,可以使用load data infile命令将文本文件导入到MySQL数据库中。其基本语法形式如下:

load data [local] infile file into table table [option];

其中,“local”是在本地计算机中查找文本文件时使用的;“file”参数指定了文本文件的路径和名称;“table”参数指标的名称;

5、用mysqlimport命令导入文本文件

MySQL中,可以使用mysqlimport命令将文本文件导入到MySQL数据库中。其基本语法形式如下:

mysqlimport -u root -pPassword [--LOCAL] dbname file [option]

其中,“Password”参数是root用户的密码,必须与-p选项紧挨着;“local”是在本地计算机中查找文本文件时使用的;“dbname”参数表示数据库的名称;“file”参数指定了文本文件的路径和名称;

五、总结

这里的相关内容还没有整理完毕,文章后面持续更新,建议收藏。

文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。

可以微信搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。

mysql的备份还原(mysqldump)(代码片段)

MySQL的备份还原(mysqldump)MySQL的还原前提是要建立在,有完全备份和二进制日志开启的前提下,并且二进制日志文件和完全备份存放在与数据库文件不同的磁盘上,否则当磁盘发生损坏数据将无法进行恢复。开启二进制日志开启二... 查看详情

mysql逻辑备份与还原工具mysqldump(代码片段)

原文:mysql逻辑备份与还原工具mysqldump(一)mysqldump介绍mysqldump是MySQL自带的逻辑备份工具,类似于Oracle的expdp/impdp,mysqldump备份十分灵活,可以在以下级别对数据库进行备份:实例下的所有数据库某个或某几个数据库某个数据库中的... 查看详情

mysql-数据备份与还原(代码片段)

...回复【学习路线图】获取学习路线图。文章目录前言一、数据备份1、使用mysqldump命令备份2、直接复制整个数据库目录3、使用mysqlhotcopy工具快速备份二、数据还原1、使用mysql命令还原2、直接复制到数据库目录三、数据库迁移1、... 查看详情

mysql物理物理备份与还原工具xtrabackup(代码片段)

原文:MySQL物理物理备份与还原工具xtraBackup(一)xtraBackup简介xtraBackup是Percona公司开发的一款MySQL数据库备份软件,在备份模式中属于物理备份。其显著特点是开源、免费、备份执行过程中不会阻塞事物、备份可压缩、支持全备和... 查看详情

详细介绍mysql中数据的备份与恢复,防止数据丢失(代码片段)

...少数据恢复数据需要在多长时间内完成需要恢复哪些数据还原要点做还原测试,用于测试备份的可用性还原演练备份类型完全备份、不分备份完全备份:整个数据集部分备份:只备份数据子集,如部分库或表增量备份、差异备份... 查看详情

mysql数据库备份还原,并还原到最新状态(mysqldump)(代码片段)

启用二进制日志文件vim/etc/my.cnf配置文件位置及文件名根据实际情况确定sql_log_bin=ON|OFF:是否记录二进制日志,默认为ON//在需要的时候设置为OFFlog_bin=/PATH/BIN_LOG_FILE:指定二进制日志文件位置;通常单独存放到与数据库不同的机器中... 查看详情

mysql逻辑备份与还原工具mysqldump(代码片段)

(一)mysqldump介绍mysqldump是MySQL自带的逻辑备份工具,类似于Oracle的expdp/impdp,mysqldump备份十分灵活,可以在以下级别对数据库进行备份:实例下的所有数据库某个或某几个数据库某个数据库中的表某个数据库中的表的某些记录mysqld... 查看详情

mysql完整备份,还原(代码片段)

#备份mysqldump-uroot-p--all-databases>sqlfile.sql#恢复mysql–uroot–psource<path>/sqlfile.sql; 查看详情

mysql的备份还原(xtrabackup)(代码片段)

MySQL的备份还原(xtrabackup)xtrabackup简介xtrabackup是percona提供的MySQL数据库的备份工具,是唯一开源的能对innodb和xtradb数据库进行热备的工具xtrabackup的特点1.备份还原过程快、可靠2.备份过程不会打断正在执行的事务3.能够基于压缩等... 查看详情

mysql数据库安全管理(代码片段)

...目录一、外键约束二、事务安全三、预处理四、视图五、数据备份与还原1、表数据备份、还原2、文件备份、还原3、SQL备份、SQL还原六、用户管理1、账号管理2、权限管理3、角色管理安全管理:用各种方式来确保数据库的安... 查看详情

mysql的备份与还原,非常规备份,全量备份,增量备份(代码片段)

一、测试数据库的创建1:官方百万级别的测试数据库:官方测试数据库github网址:https://github.com/datacharmer/test_db下载到目录,解压即可,运行命令:mysql-uroot-p<employees.sqlmysql-uroot-p<employees_partitioned.sql2&#... 查看详情

sh从转储文件还原mysql数据库(代码片段)

查看详情

mongodb备份与还原(代码片段)

MongoDB备份与还原今天迁移MongoDB数据库出现了很奇怪的问题,使用的方法如下:备份方法:mongodump-hdbhost-ddbname-odbdirectory还原方法:mongorestore-h<hostname><:port>-ddbname<path>备份正常,但还原出现报错:Failed:blog.posts:errorres... 查看详情

mysql备份还原数据库数据库迁移(代码片段)

导出整个数据库mysqldump-hip-u用户名-p数据库名>copy.sql或导出一个表mysqldump-hip-u用户名-p数据库名表名>copy_users.sql导入数据库mysql-uroot-p//登陆mysql>use数据库名mysql>setnamesutf8//编码,不是UTF-8mysql>sourcefilepath\copy.sqlwarn 查看详情

(4.12)mysql备份还原——mysql逻辑备份之mysqldump(代码片段)

关键词:mysql逻辑备份介绍,mysqldump1、mysql逻辑备份介绍  【1.1】备份内容:数据库的结构定义语句+数据内容的插入语句,备份出来的文件可以编辑  【1.2】使用场景:数据量较少的库,比较适合100G数据量以内的  逻辑... 查看详情

[javaweb-mysql]数据库的备份和还原(代码片段)

数据库的备份和还原1.命令行: *语法: *备份:mysqldump-u用户名-p密码数据库名称>保存的路径 *还原: 1.登录数据库 2.创建数据库 3.使用数据库 4.执行文件。source文件路径2.图形化工具:备份完成!!!现... 查看详情

[知了堂学习笔记]_java代码实现mysql数据库的备份与还原

通常在MySQL数据库的备份和恢复的时候,多是采用在cmd中执行mysql命令来实现。    例如:    mysqldump-h127.0.0.1-uroot-ppasstest>d:/test.sql---备份test数据库到D盘    mysql-h127.0.0.1-uroot-ppasstest<test.sql---将D备份的数据库脚... 查看详情

mariadbxtrabackup物理备份与还原(代码片段)

xtrabackup物理备份1.1安装xtraback安装依赖:[[email protected]~]#yuminstall-yperl-DBD-MySQLperl-DBIperl-Time-HiReslibaio*安装:[[email protected]~]#rpm-ivhpercona-xtrabackup-2.1.5-680.rhel6.x86_64.rpmPrepa 查看详情