2005-06-26

mysqldump常用的选项

germa83上的mysql有超过3个G的数据,在重装系统时难免要把数据备份,我使用的是备份mysql数据库的常见工具,mysqldump。在备份时,使用了mysqldump --opt DWBdatabase > DWBdatabase.sql。阅读mysql的手册才知道,其实--opt在4.1版本以上是默认打开的(As of MySQL 4.1, --opt is on by default, but can be disabled with --skip-opt)。在导入数据时我先用create database DWBdatabase,然后用mysql DWBdatabase DWBdatabase.sql 就可以避免这样的麻烦。看来仔细阅读手册还是很有用的。总结一下常见用法:

mysqldump最常见的用法是:
shell> mysqldump --opt -u username --password="password" db_name > backupfile.sql
shell>mysqldump --opt -u username --password="password" db_name > backupfile.sql

或者压缩备份文件:
#mysqldump --opt -u user --password="password" database | bzip2 -c > database.sql.bz2

在dbname已经存在的情况下,读入备份文件恢复数据库,

shell> mysql db_name mysql -e "source /path-to-backup/backup-file.sql" db_name

mysqldump 还可以用于在两个mysql server之间复制数据:

shell> mysqldump --opt db_name | mysql --host=remote_host -C db_name

也可以同时备份多个数据库:

shell> mysqldump --databases db_name1 [db_name2 ...] > my_databases.sql

如果想一次备份整个数据库使用 --all-databases 选项:

shell> mysqldump --all-databases > all_databases.sql

常见选项:
--add-drop-table:添加DROP TABLE语句
--add-locks:用LOCK TABLES 和 UNLOCK TABLES 语句封装插入每个表格的语句,能加速数据导入速度
--all-databases, -A: 备份所有数据库
--compress, -C:用于在两个server之间复制时压缩数据
--databases, -B: 用于备份多个数据库,如果没有该选项,mysqldump 把第一个名字参数作为数据库名,后面的作为表名。使用该选项,mysqldum把每个名字都当作为数据库名。CREATE DATABASE IF NOT EXISTS db_name and USE db_name 会被添加到导出文件里。
--force, -f:即使发现sql错误,仍然继续备份
--host=host_name, -h host_name:备份主机名,默认为localhost
--no-data, -d:只导出表结构
--opt:等同于激活--add-drop-table --add-locks --create-options --disable-keys --extended-insert --lock-tables --quick --set-charset这些选项
--password[=password], -p[password]:密码
--port=port_num, -P port_num:制定TCP/IP连接时的端口号
--protocol={TCP | SOCKET | PIPE | MEMORY}:制定连接所用的协议
--quick, -q:快速导出
--socket=path, -S path:当连接至localhost时,制定socket文件
--tables:覆盖 --databases or -B选项,后面所跟参数被视作表名
--user=user_name, -u user_name:用户名
--xml, -X:导出为xml文件

没有评论:

发表评论