MySQL数据库备份与恢复.doc

上传人:豆**** 文档编号:23953785 上传时间:2022-07-02 格式:DOC 页数:46 大小:164KB
返回 下载 相关 举报
MySQL数据库备份与恢复.doc_第1页
第1页 / 共46页
MySQL数据库备份与恢复.doc_第2页
第2页 / 共46页
点击查看更多>>
资源描述

《MySQL数据库备份与恢复.doc》由会员分享,可在线阅读,更多相关《MySQL数据库备份与恢复.doc(46页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateMySQL数据库备份与恢复备份是最简单的保护数据的方法,本节将介绍多种备份方法备份是最简单的保护数据的方法,本节将介绍多种备份方法。为了得到一个一致的备份,在相关的表上做一个LOCK TABLES,你只需一个读锁定,当你在数据库目录中做文件的一个拷贝时,这允许其他线程继续查询该表;当你恢复数据时,需要一个写锁定,以避免冲突。使用SQL语句备份和恢复你可以使用SELEC

2、T INTO OUTFILE语句备份数据,并用LOAD DATA INFILE语句恢复数据。这种方法只能导出数据的内容,不包括表的结构,如果表的结构文件损坏,你必须要先恢复原来的表的结构。语法:SELECT * INTO OUTFILE | DUMPFILE file_name FROM tbl_nameLOAD DATA LOW_PRIORITY LOCAL INFILE file_name.txt REPLACE | IGNOREINTO TABLE tbl_nameSELECT . INTO OUTFILE file_name格式的SELECT语句将选择的行写入一个文件。文件在服务器主机

3、上被创建,并且不能是已经存在的(不管别的,这可阻止数据库表和文件例如“/etc/passwd”被破坏)。SELECT . INTO OUTFILE是LOAD DATA INFILE逆操作。LOAD DATA INFILE语句从一个文本文件中以很高的速度读入一个表中。如果指定LOCAL关键词,从客户主机读文件。如果LOCAL没指定,文件必须位于服务器上。(LOCAL在MySQL3.22.6或以后版本中可用。)为了安全原因,当读取位于服务器上的文本文件时,文件必须处于数据库目录或可被所有人读取。另外,为了对服务器上文件使用LOAD DATA INFILE,在服务器主机上你必须有file的权限。使用

4、这种SELECT INTO OUTFILE语句,在服务器主机上你必须有FILE权限。为了避免重复记录,在表中你需要一个PRIMARY KEY或UNIQUE索引。当在唯一索引值上一个新记录与一个老记录重复时,REPLACE关键词使得老记录用一个新记录替代。如果你指定IGNORE,跳过有唯一索引的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复索引值时,出现一个错误,并且文本文件的余下部分被忽略时。如果你指定关键词LOW_PRIORITY,LOAD DATA语句的执行被推迟到没有其他客户读取表后。 使用LOCAL将比让服务器直接存取文件慢些,因为文件的内容必须从客户主机传送到服务器主机。

5、在另一方面,你不需要file权限装载本地文件。如果你使用LOCAL关键词从一个本地文件装载数据,服务器没有办法在操作的当中停止文件的传输,因此缺省的行为好像IGNORE被指定一样。当在服务器主机上寻找文件时,服务器使用下列规则:如果给出一个绝对路径名,服务器使用该路径名。 如果给出一个有一个或多个前置部件的相对路径名,服务器相对服务器的数据目录搜索文件。 如果给出一个没有前置部件的一个文件名,服务器在当前数据库的数据库目录寻找文件。假定表tbl_name具有一个PRIMARY KEY或UNIQUE索引,备份一个数据表的过程如下:1、锁定数据表,避免在备份过程中,表被更新mysqlLOCK TA

6、BLES READ tbl_name;2、导出数据mysqlSELECT * INTO OUTFILE tbl_name.bak FROM tbl_name;3、解锁表mysqlUNLOCK TABLES;相应的恢复备份的数据的过程如下:1、为表增加一个写锁定:mysqlLOCK TABLES tbl_name WRITE;2、恢复数据mysqlLOAD DATA INFILE tbl_name.bak -REPLACE INTO TABLE tbl_name;如果,你指定一个LOW_PRIORITY关键字,就不必如上要对表锁定,因为数据的导入将被推迟到没有客户读表为止:mysqlLOAD D

7、ATA LOW_PRIORITY INFILE tbl_name -REPLACE INTO TABLE tbl_name;3、解锁表使用mysqlimport恢复数据如果你仅仅恢复数据,那么完全没有必要在客户机中执行SQL语句,因为你可以简单的使用mysqlimport程序,它完全是与LOAD DATA 语句对应的,由发送一个LOAD DATA INFILE命令到服务器来运作。执行命令mysqlimport -help,仔细查看输出,你可以从这里得到帮助。shell mysqlimport options db_name filename .对于在命令行上命名的每个文本文件,mysqlimp

8、ort剥去文件名的扩展名并且使用它决定哪个表导入文件的内容。例如,名为“patient.txt”、“patient.text”和“patient”将全部被导入名为patient的一个表中。 常用的选项为:-C, -compress 如果客户和服务器均支持压缩,压缩两者之间的所有信息。-d, -delete 在导入文本文件前倒空表格。l, -lock-tables 在处理任何文本文件前为写入所定所有的表。这保证所有的表在服务器上被同步。-low-priority,-local,-replace,-ignore分别对应LOAD DATA语句的LOW_PRIORITY,LOCAL,REPLACE,I

9、GNORE关键字。例如恢复数据库db1中表tbl1的数据,保存数据的文件为tbl1.bak,假定你在服务器主机上:shellmysqlimport -lock-tables -replace db1 tbl1.bak这样在恢复数据之前现对表锁定,也可以利用-low-priority选项:shellmysqlimport -low-priority -replace db1 tbl1.bak如果你为远程的服务器恢复数据,还可以这样:shellmysqlimport -C -lock-tables -replace db1 tbl1.bak当然,解压缩要消耗CPU时间。象其它客户机一样,你可能需要

10、提供-u,-p选项以通过身分验证,也可以在选项文件f中存储这些参数,具体方法和其它客户机一样,这里就不详述了。mysql-UNLOCAK TABLES; 用mysqldump备份数据同mysqlimport一样,也存在一个工具mysqldump备份数据,但是它比SQL语句多做的工作是可以在导出的文件中包括SQL语句,因此可以备份数据库表的结构,而且可以备份一个数据库,甚至整个数据库系统。mysqldump OPTIONS database tablesmysqldump OPTIONS -databases OPTIONS DB1 DB2 DB3.mysqldump OPTIONS -all-

11、databases OPTIONS如果你不给定任何表,整个数据库将被倾倒。 通过执行mysqldump -help,你能得到你mysqldump的版本支持的选项表。 1、备份数据库的方法例如,假定你在服务器主机上备份数据库db_nameshell mydqldump db_name当然,由于mysqldump缺省时把输出定位到标准输出,你需要重定向标准输出。例如,把数据库备份到bd_name.bak中:shell mydqldump db_namedb_name.bak你可以备份多个数据库,注意这种方法将不能指定数据表:shell mydqldump -databases db1 db1db.

12、bak你也可以备份整个数据库系统的拷贝,不过对于一个庞大的系统,这样做没有什么实际的价值:shell mydqldump -all-databasesdb.bak虽然用mysqldump导出表的结构很有用,但是恢复大量数据时,众多SQL语句使恢复的效率降低。你可以通过使用-tab选项,分开数据和创建表的SQL语句。-T,-tab= 在选项指定的目录里,创建用制表符(tab)分隔列值的数据文件和包含创建表结构的SQL语句的文件,分别用扩展名.txt和.sql表示。该选项不能与-databases或-all-databases同时使用,并且mysqldump必须运行在服务器主机上。例如,假设数据库

13、db包括表tbl1,tbl2,你准备备份它们到/var/mysqldbshellmysqldump -tab=/var/mysqldb/ db其效果是在目录/var/mysqldb中生成4个文件,分别是tbl1.txt、tbl1.sql、tbl2.txt和tbl2.sql。2、mysqldump实用程序时的身份验证的问题 同其他客户机一样,你也必须提供一个MySQL数据库帐号用来导出数据库,如果你不是使用匿名用户的话,可能需要手工提供参数或者使用选项文件:如果这样:shellmysql -u root pmypass db_namedb_name.sql或者这样在选项文件中提供参数:mysql

14、dumpuser=rootpassword=mypass然后执行shellmysqldump db_namedb_name.sql那么一切顺利,不会有任何问题,但要注意命令历史会泄漏密码,或者不能让任何除你之外的用户能够访问选项文件,由于数据库服务器也需要这个选项文件时,选项文件只能被启动服务器的用户(如,mysql)拥有和访问,以免泄密。在Unix下你还有一个解决办法,可以在自己的用户目录中提供个人选项文件(/f),例如,/home/some_user/f,然后把上面的内容加入文件中,注意防止泄密。在NT系统中,你可以简单的让c:f能被指定的用户访问。你可能要问,为什么这么麻烦呢,例如,这样

15、使用命令行:shellmysql -u root p db_namedb_name.sql或者在选项文件中加入mysqldumpuser=rootpassword然后执行命令行:shellmysql db_namedb_name.sql你发现了什么?往常熟悉的Enter password:提示并没有出现,因为标准输出被重定向到文件db_name.sql中了,所以看不到往常的提示符,程序在等待你输入密码。在重定向的情况下,再使用交互模式,就会有问题。在上面的情况下,你还可以直接输入密码。然后在文件db_name.sql文件的第一行看到:Enter password:#.你可能说问题不大,但是my

16、sqldump之所以把结果输出到标准输出,是为了重定向到其它程序的标准输入,这样有利于编写脚本。例如:用来自于一个数据库的信息充实另外一个MySQL数据库也是有用的: shellmysqldump -opt database | mysql -host=remote-host -C database如果mysqldump仍运行在提示输入密码的交互模式下,该命令不会成功,但是如果mysql是否运行在提示输入密码的交互模式下,都是可以的。如果在选项文件中的client或者mysqldump任何一段中指定了password选项,且不提供密码,即使,在另一段中有提供密码的选项password=mypa

17、ss,例如clientuser=rootpasswordmysqldumpuser=adminpassword=mypass那么mysqldump一定要你输入admin用户的密码:mysqlmysqldump db_name即使是这样使用命令行:mysqlmysqldump u root ppass1 db也是这样,不过要如果-u指定的用户的密码。其它使用选项文件的客户程序也是这样3、有关生成SQL语句的优化控制-add-locks 生成的SQL 语句中,在每个表数据恢复之前增加LOCK TABLES并且之后UNLOCK TABLE。(为了使得更快地插入到MySQL)。 -add-drop-t

18、able 生成的SQL 语句中,在每个create语句之前增加一个drop table。 -e, -extended-insert 使用全新多行INSERT语法。(给出更紧缩并且更快的插入语句) 下面两个选项能够加快备份表的速度:-l, -lock-tables. 为开始导出数据前,读锁定所有涉及的表。-q, -quick 不缓冲查询,直接倾倒至stdout。理论上,备份时你应该指定上诉所有选项。这样会使命令行过于复杂,作为代替,你可以简单的指定一个-opt选项,它会使上述所有选项有效。例如,你将导出一个很大的数据库:shell mysqldump -opt db_name db_name.t

19、xt当然,使用-tab选项时,由于不生成恢复数据的SQL语句,使用-opt时,只会加快数据导出。4、恢复mysqldump备份的数据由于备份文件是SQL语句的集合,所以需要在批处理模式下使用客户机如果你使用mysqldump备份单个数据库或表,即:shellmysqldump -opt db_name db_name.sql由于db_name.sql中不包括创建数据库或者选取数据库的语句,你需要指定数据库shellmysql db2 mysqldump -databases db_name db_name.sqlshellmysql 如果你使用-tab选项备份数据,数据恢复可能效率会高些例如,

20、备份数据库db_name后在恢复:shellmysqldump -tab=/path/to/dir -opt test如果要恢复表的结构,可以这样:shellmysql mysqlimport -l db /path/to/dir/tbl1.txt如果是在Unix平台下使用(推荐),就更方便了:shellls -l *.sql | mysql dbshellmysqlimport -lock-tables db /path/to/dir/*.txt用直接拷贝的方法备份恢复根据本章前两节的介绍,由于MySQL的数据库和表是直接通过目录和表文件实现的,因此直接复制文件来备份数据库数据,对MySQL

21、来说特别方便。而且自MySQL 3.23起MyISAM表成为缺省的表的类型,这种表可以为在不同的硬件体系中共享数据提供了保证。使用直接拷贝的方法备份时,尤其要注意表没有被使用,你应该首先对表进行读锁定。备份一个表,需要三个文件:对于MyISAM表:tbl_name.frm 表的描述文件tbl_name.MYD 表的数据文件tbl_name.MYI 表的索引文件对于ISAM表:tbl_name.frm 表的描述文件tbl_name.ISD 表的数据文件tbl_name.ISM 表的索引文件你直接拷贝文件从一个数据库服务器到另一个服务器,对于MyISAM表,你可以从运行在不同硬件系统的服务器之间复制文件,例如,SUN服务器和INTEL PC机之间。总结本节介绍了备份恢复数据库的多种方法,读者可以根据需要选用,对于文中涉及到的SQL语句、工具主要有:1、SELECTINTO OUTFILE和LOAD DATA INFILE2、mysqldump3、mysqlimport对于这些内容,读者需要注重掌握的是mysqldump实用程序的使用,以及mysql批处理模式运行包含SQL语句的文件的方法。这在备份和恢复数据库表中非常常用。另外要注意的是直接拷贝的方法。-

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 小学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com