1. 备份和恢复需求分析
数据库中的数据丢失或被破坏可能是由于以下原因:
(1)计算机硬件故障。由于使用不当或产品质量等原因,计算机硬件可能会出现故障,不能使用。如硬盘损坏会使得存储于其上的数据丢失。
(2)软件故障。由于软件设计上的失误或用户使用的不当,软件系统可能会误操作数据引起数据破坏。
(3)病毒。破坏性病毒会破坏系统软件、硬件和数据。
(4)误操作。如用户误使用了诸如DELETE、UPDATE等命令而引起数据丢失或破坏。
(5)自然灾害。如火灾、洪水或地震等,它们会造成极大的破坏,会毁坏计算机系统及其数据。
(6)盗窃。一些重要数据可能会遭窃。
因此,必须制作数据库的复本,即进行数据库备份,在数据库遭到破坏时能够修复数据库,即进行数据库恢复,数据库恢复就是把数据库从错误状态恢复到某一正确状态。
备份和恢复数据库也可以用于其他目的,如可以通过备份与恢复将数据库从一个服务器移动或复制到另一个服务器。
2. 数据恢复的手段
有多种可能会导致数据表的丢失或者服务器的崩溃,一个简单的DROP TABLE或者DROP DATABASE的语句,就会让数据表化为乌有。更危险的是DELETE *FROM table_name,可以轻易地清空数据表,而这样的错误是很容易发生的。
因此,拥有能够恢复的数据对于一个数据库系统来说是非常重要的。MySQL有三种保证数据安全的方法。
(1)数据库备份:通过导出数据或者表文件的拷贝来保护数据。
(2)二进制日志文件:保存更新数据的所有语句。
(3)数据库复制:MySQL内部复制功能建立在两个或两个以上服务器之间,通过设定它们之间的主从关系来实现的。其中一个作为主服务器,其他的作为从服务器。在此主要介绍前两种方法。
数据库恢复就是当数据库出现故障时,将备份的数据库加载到系统,从而使数据库恢复到备份时的正确状态。
恢复是与备份相对应的系统维护和管理操作,系统进行恢复操作时,先执行一些系统安全性的检查,包括检查所要恢复的数据库是否存在、数据库是否变化及数据库文件是否兼容等,然后根据所采用的数据库备份类型采取相应的恢复措施。
3. 使用客户端程序备份和恢复
MySQL提供了很多免费的客户端程序和实用工具,不同的MySQL客户端程序可以连接服务器以访问数据库或执行不同的管理任务。这些程序不与服务器进行通信,但可以执行MySQL相关的操作。在MySQL目录下的BIN子目录中存储着这些客户端程序。
这里简单介绍一下mysqldump程序和mysqlimport程序。使用客户端的方法:打开DOS终端,进入BIN目录,路径为:C:\Program Files\MySQL\MySQLServer 5.1\bin,后面介绍的客户端命令都在此处输入,
1). 使用mysqldump备份数据
mysqldump客户端也可用于备份数据,它比SQL语句多做的工作是可以在导出的文件中包含表结构的SQL语句,因此可以备份数据库表的结构,而且可以备份一个数据库,甚至整个数据库系统。
(1_1)备份表
命令格式:mysqldump[options] db_name [tables] > filename
说明:options是mysqldump命令支持的选项,可以通过执行mysqldump -help命令得到mysqldump选项表及帮助信息,这里不详细列出。db_name是数据库名,后面可以跟需要备份的表名。Filename为最后备份的文件名,如果该语句中有多个表,则都保存在这个文件中,文件默认的保存地址是MySQL的bin目录下。如果要保存在特定位置,可以指定其具体路径。注意,文件名在目录中不能已经存在,否则新的备份文件将会将原文件覆盖,造成不必要的麻烦。
同其他客户端程序一样,备份数据时需要使用一个用户账号连接到服务器,这需要用户手工提供参数或在选项文件中修改有关值。参数格式为:-h[hostname] -u[username] -p[password]
其中,-h后是主机名,-u后是用户名,-p是用户密码,-p选项和密码之间不能有空格。
例: 使用mysqldump备份XS表和KC表。具体命令如下:
mysqldump -h localhost -u root -p123456XSCJ XS KC > twotables.sql
说明:如果是本地服务器,-h选项可以省略。在MySQL的bin目录下可以看到,已经保存了一个.sql格式的文件,文件中存储了创建XS表和KC表的一系列SQL语句。
注意:若在命令中没有表名,则备份整个数据库。
(1_2)备份数据库
mysqldump程序还可以将一个或多个数据库备份到一个文件中。
命令格式:
mysqldump [options] --databases DB1[DB2 DB3...] > filename
例: 备份XSCJ数据库和mysql数据库到D盘FILE文件夹下。
命令如下: mysqldump -uroot -p123456 --databases XSCJmysql>D:/FILE/data.sql
说明:命令执行完后,在FILE文件夹下的data.sql文件被创建了,其中存储了XSCJ数据库和mysql数据库的全部SQL语句。
mysql还能备份整个数据库系统,即系统中的所有数据库。
例:备份MySQL服务器上的所有数据库。使用如下命令:
mysqldump -uroot -p123456--all-databases>all.sql
虽然用mysqldump导出表的结构很有用,但是在恢复数据时,如果数据量很大,众多SQL语句将使恢复的效率降低。可以通过使用--tab=选项,分开数据和创建表的SQL语句。--tab=选项会在选项中“=”后面指定的目录里,分别创建存储数据内容的.txt格式文件和包含创建表结构的SQL语句的.sql格式文件。该选项不能与--databases或--all-databases同时使用,并且mysqldump必须运行在服务器主机上。
例: 将XSCJ数据库中所有表的表结构和数据都分别备份到D盘FILE文件夹下。命令如下:
mysqldump -uroot -p123456 --tab=D:/FILE/ XSCJ
其效果是在目录FILE中生成6个文件,分别是xs.txt、xs.sql、kc.txt、kc.sql、xs_kc.txt和xs_kc.sql。
(1_3)恢复数据库
mysqldump程序备份的文件中存储的是SQL语句的集合,用户可以将这些语句还原到服务器中以恢复一个损坏的数据库。
例:假设XSCJ数据库损坏,用备份文件将其恢复。
备份XSCJ数据库的命令为:
mysqldump -uroot -p123456 XSCJ>XSCJ.sql
恢复命令为:
mysql -uroot -p123456 XSCJ<XSCJ.sql
2). 使用mysqlimport恢复数据
mysqlimport客户端可以用来恢复表中的数据,它提供了LOADDATA INFILE语句的一个命令行接口,发送一个LOAD DATA INFILE命令到服务器来运作。它大多数选项直接对应LOAD DATA INFILE语句。
mysqlimport命令格式为:
mysqlimport [options] db_name filename ...
说明:options是mysqlimport命令的选项,使用mysqlimport -help即可查看这些选项的内容和作用。常用的选项为:
-d,--delete:在导入文本文件前清空表格。
- -lock-tables:在处理任何文本文件前锁定所有的表。这保证所有的表在服务器上同步。而对于InnoDB类型的表则不必进行锁定。
--low-priority,--local,--replace,--ignore:分别对应LOAD DATA INFILE语句的LOW_PRIORITY,LOCAL,REPLACE,IGNORE关键字。
对于在命令行上命名的每个文本文件,mysqlimport剥去文件名的扩展名,并使用它决定向哪个表导入文件的内容。例如,“patient.txt”、“patient.sql”和“patient”都会被导入名为patient的表中。所以备份的文件名应根据需要恢复表命名。
例: 恢复XSCJ数据库中表XS的数据,保存数据的文件为XS.txt,命令如下:mysqlimport -uroot -p123456 --low-priority n --replace XSCJ XS.txt
mysqlimport也需要提供-u、-p选项来连接服务器。值得注意的是,mysqlimport是通过执行LOAD DATA INFILE语句来恢复数据库的,所以上例中备份文件未指定位置的默认是在MySQL的DATA目录中。如果不在则要指定文件的具体路径。
2). 使用mysqlimport恢复数据
mysqlimport客户端可以用来恢复表中的数据,它提供了LOADDATA INFILE语句的一个命令行接口,发送一个LOAD DATA INFILE命令到服务器来运作。它大多数选项直接对应LOAD DATA INFILE语句。
mysqlimport命令格式为:
mysqlimport [options] db_name filename...
说明:options是mysqlimport命令的选项,使用mysqlimport -help即可查看这些选项的内容和作用。常用的选项为:
-d,--delete:在导入文本文件前清空表格。
--lock-tables:在处理任何文本文件前锁定所有的表。这保证所有的表在服务器上同步。而对于InnoDB类型的表则不必进行锁定。
--low-priority,--local,--replace,--ignore:分别对应LOAD DATA INFILE语句的LOW_PRIORITY,LOCAL,REPLACE,IGNORE关键字。
对于在命令行上命名的每个文本文件,mysqlimport剥去文件名的扩展名,并使用它决定向哪个表导入文件的内容。例如,“patient.txt”、“patient.sql”和“patient”都会被导入名为patient的表中。所以备份的文件名应根据需要恢复表命名。
例: 恢复XSCJ数据库中表XS的数据,保存数据的文件为XS.txt,命令如下:mysqlimport -uroot -p123456 --low-priority --replace XSCJ XS.txt
mysqlimport也需要提供-u、-p选项来连接服务器。值得注意的是,mysqlimport是通过执行LOAD DATA INFILE语句来恢复数据库的,所以上例中备份文件未指定位置的默认是在MySQL的DATA目录中。如果不在则要指定文件的具体路径。