您正在使用IPV4(3.236.138.35)访问本站 您本次共访问本站 1 次
 用户名: 密 码: 验证码:     用QQ登录本站
首页 软件 编程 笑话 知识 公告 台风 日历 计算器
[公益]文明驾车我带头,文明行路我带头,礼貌让座我带头       悟空收录网      

【腾讯云】云服务器等爆品抢先购,低至4.2元/月      
[公益] 节省一分零钱 献出一份爱心 温暖世间真情      
2023年 元宵节 8
2023年 情人节 17
2024年 元 旦 338
2024年 春 节 378
 
您现在的位置:首页 >> 数据库 >> 内容
本类新增
本类热门文章
MySQL数据备份、还原、数据库迁移以及表的导出和导入
内容摘要: 一、数据备份备份数据是数据库管理中最常用的操作。为了保证数据库中数据的去安全,数据库管理员需要定期的进行数据库备份。一旦数据库遭到破坏,即通过备份的文件来还原数据库。因此,数据备份是很重要的工作。1、使用mysqldump命令备份mysqldump命令可以将数据库中的数据备份成一个文本文件。表的结构和表中的数据将存储在生成的文本文件中。mysqldump命令......
一、数据备份

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

1、使用mysqldump命令备份

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

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

1、备份一个数据库

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

mysqldump-uusername-pdbnametable1table2...>backupname.sql

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

2、备份多个数据库

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

mysqldump-uusername-p--databasesdbname1dbname2...>backupname.sql

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

3、备份所有数据库

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

mysqldump-uusername-p--all-databases>backupname.sql

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

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

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

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

3、使用mysqlhotcopy工具快速备份

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

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

mysqlhotcopy[option]dbname1dbname2...backupDir/

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

二、数据还原

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

1、使用mysql命令还原

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

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

mysql-uroot-p[dbname]<backup.sql

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

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

mysql-uroot-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-hname1-uroot--password1--all-databases|

mysql-hhost2-uroot--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…intooutfile导出文本文件

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

select[列名]fromtable[where语句]intooutfile'目标文件'[option];

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

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

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

mysqldump-uroot-pPassword-T目标目录dbnametable[option];

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

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

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

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

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

4、用loaddatainfile方式导入文本文件

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

loaddata[local]infilefileintotabletable[option];

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

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

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

mysqlimport-uroot-pPassword[--LOCAL]dbnamefile[option]

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

版权声明:本内容来源于网络,如有侵犯您的版权,请联系站长,本站收到您的信息后将及时处理。
上一篇:mysql如何开启各种日志 下一篇:oracle自动生成uuid的实现方法
发布日期:2022/11/9
手机扫二维码直达本页
发布时间:18:07:47
点  击:4
录  入:壹家怡园
相关文章
Baidu

YiJiaCMS 6.3.5.220928(MSSQL) 闽ICP备05000814号-1
本空间由腾讯云(轻量应用服务器)提供,百度云加速提供加速防护
Copyright©2000-2023