共计 4008 个字符,预计需要花费 11 分钟才能阅读完成。
今天就跟大家聊聊有关 MySQL 中怎么备份和恢复数据表,可能很多人都不太了解,为了让大家更加了解,丸趣 TV 小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
你可以使用 SELECT INTO OUTFILE 语句备份数据,并用 LOAD DATA INFILE 语句恢复数据。这种方法只能导出数据的内容,不包括表的结构,如果表的结构文件损坏,你必须要先恢复原来的表的结构。
语法:
SELECT * INTO {OUTFILE | DUMPFILE} file_name FROM tbl_name
LOAD DATA [LOW_PRIORITY] [LOCAL] INFILE file_name.txt [REPLACE | IGNORE]
INTO TABLE tbl_name
SELECT … INTO OUTFILE file_name 格式的 SELECT 语句将选择的行写入一个文件。文件在服务器主机上被创建,并且不能是已经存在的 (不管别的,这可阻止数据库表和 文件例如“/etc/passwd”被破坏)。SELECT … INTO OUTFILE 是 LOAD DATA INFILE 逆操作。
LOAD DATA INFILE 语句从一个文本文件中以很高的速度读入一个表中。如果指定 LOCAL 关键词,从客户主机读文件。如果 LOCAL 没指定,文件必须位于服务器上。(LOCAL 在 MySQL3.22.6 或以后版本中可用。)
为 了安全原因,当读取位于服务器上的文本文件时,文件必须处于数据库目录或可被所有人读取。另外,为了对服务器上文件使用 LOAD DATA INFILE,在服务器主机上你必须有 file 的权限。使用这种 SELECT INTO OUTFILE 语句,在服务器主机上你必须有 FILE 权限。
为 了避免重复记录,在表中你需要一个 PRIMARY KEY 或 UNIQUE 索引。当在唯一索引值上一个新记录与一个老记录重复时,REPLACE 关键词使得老记录用一个新记录替代。如果你指定 IGNORE,跳过有唯一索引的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复索引值时,出现一个错误,并且文本文件的余下部分被忽略时。
如果你指定关键词 LOW_PRIORITY,LOAD DATA 语句的执行被推迟到没有其他客户读取表后。
使 用 LOCAL 将比让服务器直接存取文件慢些,因为文件的内容必须从客户主机传送到服务器主机。在另一方面,你不需要 file 权限装载本地文件。如果你使用 LOCAL 关键词从一个本地文件装载数据,服务器没有办法在操作的当中停止文件的传输,因此缺省的行为好像 IGNORE 被指定一样。
当在服务器主机上寻找文件时,服务器使用下列规则:
◆如果给出一个绝对路径名,服务器使用该路径名。
◆如果给出一个有一个或多个前置部件的相对路径名,服务器相对服务器的数据目录搜索文件。
◆如果给出一个没有前置部件的一个文件名,服务器在当前数据库的数据库目录寻找文件。
假定表 tbl_name 具有一个 PRIMARY KEY 或 UNIQUE 索引,备份一个数据表的过程如下:
1、锁定数据表,避免在备份过程中,表被更新
mysql LOCK TABLES READ tbl_name;
2、导出数据
mysql SELECT * INTO OUTFILE lsquo;tbl_name.bak rsquo; FROM tbl_name;
3、解锁表
mysql UNLOCK TABLES;
相应的恢复备份的数据的过程如下:
1、为表增加一个写锁定:
mysql LOCK TABLES tbl_name WRITE;
2、恢复数据
mysql LOAD DATA INFILE lsquo;tbl_name.bak rsquo;
– REPLACE INTO TABLE tbl_name;
如果,你指定一个 LOW_PRIORITY 关键字,就不必如上要对表锁定,因为数据的导入将被推迟到没有客户读表为止:
mysql LOAD DATA LOW_PRIORITY INFILE lsquo;tbl_name rsquo;
– REPLACE INTO TABLE tbl_name;
3、解锁表
使用 mysqlimport 恢复数据
如 果你仅仅恢复数据,那么完全没有必要在客户机中执行 SQL 语句,因为你可以简单的使用 mysqlimport 程序,它完全是与 LOAD DATA 语句对应的,由发送一个 LOAD DATA INFILE 命令到服务器来运作。执行命令 mysqlimport –help,仔细查看输出,你可以从这里得到帮助。
shell mysqlimport [options] db_name filename …
对于在命令行上命名的每个文本文件,mysqlimport 剥去文件名的扩展名并且使用它决定哪个表导入文件的内容。例如,名为“patient.txt”、
“patient.text”和“patient”将全部被导入名为 patient 的一个表中。
常用的选项为:
-C, –compress 如果客户和服务器均支持压缩,压缩两者之间的所有信息。
-d, –delete 在导入文本文件前倒空表格。
l, –lock-tables 在处理任何文本文件前为写入所定所有的表。这保证所有的表在服务器上被同步。
–low-priority,–local,–replace,–ignore 分别对应 LOAD DATA 语句的 LOW_PRIORITY,LOCAL,REPLACE,IGNORE 关键字。
例如恢复数据库 db1 中表 tbl1 的数据,保存数据的文件为 tbl1.bak,假定你在服务器主机上:
shell mysqlimport –lock-tables –replace db1 tbl1.bak
这样在恢复数据之前现对表锁定,也可以利用 –low-priority 选项:
shell mysqlimport –low-priority –replace db1 tbl1.bak
如果你为远程的服务器恢复数据,还可以这样:
shell mysqlimport -C –lock-tables –replace db1 tbl1.bak
当然,解压缩要消耗 CPU 时间。
象其它客户机一样,你可能需要提供 -u,- p 选项以通过身分验证,也可以在选项文件 my.cnf 中存储这些参数,具体方法和其它客户机一样,这里就不详述了。
mysql- UNLOCAK TABLES;
用 mysqldump 备份数据
同 mysqlimport 一样,也存在一个工具 mysqldump 备份数据,但是它比 SQL 语句多做的工作是可以在导出的文件中包括 SQL 语句,因此可以备份数据库表的结构,而且可以备份一个数据库,甚至整个数据库系统。
mysqldump [OPTIONS] database [tables]
mysqldump [OPTIONS] –databases [OPTIONS] DB1 [DB2 DB3…]
mysqldump [OPTIONS] –all-databases [OPTIONS]
如果你不给定任何表,整个数据库将被倾倒。
通过执行 mysqldump –help,你能得到你 mysqldump 的版本支持的选项表。
1、备份数据库的方法
例如,假定你在服务器主机上备份数据库 db_name
shell mydqldump db_name
当然,由于 mysqldump 缺省时把输出定位到标准输出,你需要重定向标准输出。
例如,把数据库备份到 bd_name.bak 中:
shell mydqldump db_name db_name.bak
你可以备份多个数据库,注意这种方法将不能指定数据表:
shell mydqldump –databases db1 db1 db.bak
你也可以备份整个数据库系统的拷贝,不过对于一个庞大的系统,这样做没有什么实际的价值:
shell mydqldump –all-databases db.bak
虽然用 mysqldump 导出表的结构很有用,但是恢复大量数据时,众多 SQL 语句使恢复的效率降低。你可以通过使用 –tab 选项,分开数据和创建表的 SQL 语句。
-T,–tab= 在选项指定的目录里,创建用制表符(tab)分隔列值的数据文件和包含创建表结构的 SQL 语句的文件,分别用扩展名.txt 和.sql 表示。该选项不能与 –databases 或 –all-databases 同时使用,并且 mysqldump 必须运行在服务器主机上。
例如,假设数据库 db 包括表 tbl1,tbl2,你准备备份它们到 /var/mysqldb
shell mysqldump –tab=/var/mysqldb/ db
其效果是在目录 /var/mysqldb 中生成 4 个文件,分别是 tbl1.txt、tbl1.sql、tbl2.txt 和 tbl2.sql。
2、mysqldump 实用程序时的身份验证的问题
同其他客户机一样,你也必须提供一个 MySQL 数据库帐号用来导出数据库,如果你不是使用匿名用户的话,可能需要手工提供参数或者使用选项文件:
如果这样:
shell mysql -u root ndash;pmypass db_name db_name.sql
或者这样在选项文件中提供参数:
[mysqldump]
user=root
password=mypass
然后执行
shell mysqldump db_name db_name.sql
那 么一切顺利,不会有任何问题,但要注意命令历史会泄漏密码,或者不能让任何除你之外的用户能够访问选项文件,由于数据库服务器也需要这个选项文件时,选项 文件只能被启动服务器的用户(如,mysql)拥有和访问,以免泄密。在 Unix 下你还有一个解决办法,可以在自己的用户目录中提供个人选项文件(~/.my.cnf), 例如,/home/some_user/.my.cnf,然后把上面的内容加入文件中,注意防止泄密。
看完上述内容,你们对 MySQL 中怎么备份和恢复数据表有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注丸趣 TV 行业资讯频道,感谢大家的支持。