mysqldump最常见的用法是:
shell> mysqldump --opt -u user --password="password" db_name > backup-file.sql
或者压缩备份文件:
#mysqldump --opt -u user --password="password" database | bzip2 -c > database.sql.bz2
在dbname已经存在的情况下,读入备份文件恢复数据库,
shell> mysql db_name < backup-file.sql (备注:建议使用--database选项)
或者shell> 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文件
没有评论:
发表评论