MySQL-快速入门(12)备份、还原
1、数据备份
1》使用MySQLdump命令备份(主要的方式)
//备份数据库中某张表(去掉表的限定,就是备份指定数据库)
//备份脚本可以重新创建表及插入数据
mysqldump -u user -h host -p pwd dbname [tbname[,tbname...]] > filename.sql
C:\Users\lfy>mysqldump -uroot -h localhost -p12345 mybatis test > C:\Users\lfy\De sktop\mybatis.test_201909072320.sql mysqldump: [Warning] Using a password on the command line interface can be insec ure. C:\Users\lfy>
//备份多个数据库,使用空格隔开 mysqldump -u user -h host -p pwd --databases [database[ database...]] > filename.sql
//备份所有数据库
mysqldump -u user -h host -p pwd --all-databases > filename.sql
//如果所有表均为MyISAM表,应该考虑使用MySQLhotcopy备份或者恢复,将会更快速。
MySQLdump还有常用的选项: --opt:该选项将打开--quick、--add-locks、--extended-insert等多个选项。使用该选项可以提供最快速的数据库转储。 --add-drop-database:在每个create database语句前添加drop database语句。 --add-drop-tables:在每个create table语句前添加drop table语句。 --add-locking:用lock tables和unclock tables语句引用每个表转储。重载转储文件时插入得更快。 --all--database,-A:转储所有数据库中的所有表。与使用--database选项相同,在命令行中命名所有数据库。 --comments[=0|1]:如果设置为0,禁止转储文件中的其他信息,例如程序版本、服务器版本和主机。--skip-comments与--comments=0的结果相同。默认值为1,既包括额外的信息。 --compact:产生少量输出。该选项禁用注释并启用--skip-add-drop-tables、--no-set-names、--skip-disable-keys、--skip-add-locking。 ...
运行:mysqldump –help获取更多选项信息。
2》直接复制整个数据库目录
因为MySQL表保存文件方式,所以可以直接复制MySQL数据库的存储目录及文件进行备份。但这种方法对InnoDB存储引擎的表不适用。还要注意不同版本数据库的数据格式问题。
3》使用MySQLhotcopy工具快速备份
MySQLhotcopy是一个Perl脚本,它使用Lock Tables、Flush Tables和cp或scp来快速备份数据库。它是备份数据库或者单个表的最快途径,但它只能运行在数据库目录所在的机器上,并且只能备份MyISAM类型的表。MySQLhotcopy运行在Unix系统中。
mysqlhotcopy db_name_1,...db_name_n /path/to/new_dirctory
2、数据还原
1》使用MySQL命令恢复
//针对备份的sql文件中包含create、insert、drop mysql -u user -p pwd [dbname] < filename.sql
//如果已经登录数据库,可以使用以下方式导入脚本文件 source filename
mysql> drop table test; Query OK, 0 rows affected (0.01 sec) mysql> source C:\Users\lfy\Desktop\mybatis.test.sql Query OK, 0 rows affected (0.00 sec) Query OK, 0 rows affected (0.00 sec) Query OK, 0 rows affected (0.00 sec) ...
2》直接复制到数据库目录
要求复制的主版本号相同,仅对MyISAM类型的表有效。
3》MySQLhotcopy工具快速恢复
chown -R mysql.mysql /var/lib/mysql/dbname
3、表的导入和导出
1》使用select…into outfile ‘filename’导出文本文件
在指定的服务器需要有写入权限。filename文件不能已存在。
select column_list from tb_name where condition into outfile \'filename\' [options] options包括fields和lines子句:
fields和lines两个子句都是自选的,但是如果两个都被指定了,fileds必须位于lines的前面。在服务器主机外的客户主机上创建结果,应该在客户主机上使用如“MySQL -e “select …” > filename”的命令来生成文件。
select…into outfile是load data infile的补语。用于语句的options部分的语法包括部分fields和lines子句,这些子句与load data infile语句同时使用。
mysql> select * from test into outfile "C:\\ProgramData\\MySQL\\MySQL Server 5.7 \\Uploads\\test0.txt"; Query OK, 6 rows affected (0.00 sec) mysql> select * from test into outfile "C:\\ProgramData\\MySQL\\MySQL Server 5.7 \\Uploads\\test1.txt" -> fields -> terminated by \',\' -> enclosed by \'\"\' -> escaped by \'\\'\' -> lines -> terminated by \'\r\n\'; Query OK, 6 rows affected (0.02 sec) mysql>
说明:
上面的输出格式限定为以","逗号分隔各字段,以"\""双引号包围字段,以“\\'”单引号作为转义字符,每行结尾以\r\n结束。
2》使用MySQLdump命令导出文本文件
mysqldump -T path -u user -p pwd dbname [tables] [options] --options选项: --fields-terminated-by=value --fields-enclosed-by=value --fields-optionally-enclosed-by=value --fields-escaped-by=value --lines-terminated-by=value
只有指定了-T参数才可以导出纯文本文件;path指示导出文件的路径;tables不指定将导出指定数据库的所有表。
[options]参数需要结合-T选项使用。
C:\Users\lfy>mysqldump -T C:\\ProgramData\\MySQL\\MySQL Server 5.7\\Uploads myba tis test -uroot -p Enter password: **** mysqldump: Got error: 1049: Unknown database \'server\' when selecting the databas e C:\Users\lfy>mysqldump -T "C:\\ProgramData\\MySQL\\MySQL Server 5.7\\Uploads" my batis test -uroot -p Enter password: **** C:\Users\lfy>
mysqldump针对路径中有空格,可以对路径使用双引号括起来,也可以使用~1替换的形式。使用mysqldump进行备份数据,会同时产生两个文件,一个sql文件,一个指定的txt文件。
使用[options]:
C:\Users\lfy>mysqldump -T "C:\\ProgramData\\MySQL\\MySQL Server 5.7\\Uploads" my batis test -uroot -p --fields-terminated-by=, --fields-optionally-enclosed-by=\" --fields-escaped-by=? --lines-terminated-by=\r\n Enter password: **** C:\Users\lfy>
说明:使用逗号“,”隔开,字段使用双引号括起来,转义字符为“?”问号,回车换行使用“\r\n”。
3》使用MySQL命令导出文本文件
如果MySQL服务器是单独的机器,用户是在一个client上进行操作,用户要把数据结果导入到client机器上,可以使用MySQL -e语句。MySQL语句导出,数据的人工可读性更强,txt文件第一行默认包含了字段名称。
mysql -u user -p pwd --execute="select语句" db_name > filename.txt
C:\Users\lfy>mysql -uroot -p --execute="select * from test" mybatis > C:\\Users\ \lfy\\Desktop\\t.txt Enter password: **** C:\Users\lfy>
MySQL命令还可以指定查询结果的显式格式,如果某行记录字段太多不能显示完全,可以使用–vartical参数,将每条记录分为多行显示。
C:\Users\lfy>mysql -uroot -p --html --execute="select * from test" mybatis > C:\ Users\lfy\Desktop\t.html Enter password: **** C:\Users\lfy>
C:\Users\lfy>mysql -uroot -p --xml --execute="select * from test" mybatis > C:\U sers\lfy\Desktop\t.xml Enter password: **** C:\Users\lfy>
4》使用load data infile方式导入文本文件
MySQL支持导入数据的语句,load data语句、source语句、MySQL语句。load data infile语句支持高速从一个文本文件中读取行,并装入一个表。文件名必须是字符串类型。
load data infile \'filename.txt\' into table tb_name [options] [ignore number lines]
--ignore number lines表示忽略文件开始处的行数,number表示忽略的行数。
options选项:
5》使用MySQLimport命令导入文本文件
mysqlimport -u user -p pwd dbname filename.txt [options] --注意,并没有指定导入的数据表的名称,数据表的名称由文件名确定,导入数据之前该表必须存在
还有更多支持的选项,使用mysqlimport –help查看。
4、数据库迁移
1》相同版本的MySQL数据库之间的迁移
相同版本号,主要是指主版本号相同。相同版本号的MySQL数据库之间的迁移,主要是数据备份和数据恢复的组合。
//将www.xxx.com主机上的MySQL数据库全部迁移到www.yyy.com主机
//上,在www.xxx.com主机(即迁出主机)上执行如下命令。
//MySQLdump导出的数据直接通过管道符"|"传递给MySQL命令导入的主机
//如果要迁移全部的数据库,可使用参数--all-databases mysqldump -h www.xxx.com -u user -p pwd dbname | mysql -h www.bcd.com -u user -p pwd
2》不同版本的MySQL数据库之间的迁移
业务数据备份当然是很重要的。主要要注意的是老版本的权限控制信息、字符集等问题。存在中文数据的表特别要注意!
3》不同数据库之间的迁移
根据实际情况使用了。数据要保存,还有数据库之间对功能支持的差异,比如字段精度、支持的数据类型差异等。