Mysql数据表备份

mysqldump备份数据

  同mysqlimport一样,也存在一个工具mysqldump备份数据,但是它比SQL语句多做的工作是可以在导出的文件中包括SQL语 句,因此可以备份数据库表的结构,而且可以备份一个数据库,甚至整个数据库系统。

  mysqldump [OPTIONS] database [tables]

  mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]

  mysqldump [OPTIONS] --all-databases [OPTIONS]

  如果你不给定任何表,整个数据库将被倾倒。

  通过执行mysqldump --help,你能得到你mysqldump的版本支持的选项表。

  1、备份数据库的方法

  例如,假定你在服务器主机上备份数据库db_name

  shell> mydqldump db_name

  当然,由于mysqldump缺省时把输出定位到标准输出,你需要重定向标准输出。

  例如,把数据库备份到bd_name.bak中:

  shell> mydqldump db_name>db_name.bak

  你可以备份多个数据库,注意这种方法将不能指定数据表:

  shell> mydqldump --databases db1 db1>db.bak

  你也可以备份整个数据库系统的拷贝,不过对于一个庞大的系统,这样做没有什么实际的价值:

  shell> mydqldump --all-databases>db.bak

  虽然用mysqldump导出表的结构很有用,但是恢复大量数据时,众多SQL语句使恢复的效率降低。你可以通过使用--tab选项,分开数据 和创建表的SQL语句。

  -T--tab= 在选项指定的目录里,创建用制表符(tab)分隔列值的数据文件和包含创建表结构的SQL语句的文件,分别用扩展名.txt.sql表示。该选项不能与 --databases--all-databases同时使用,并且mysqldump必须运行在服务器主机上。

  例如,假设数据库db包括表tbl1tbl2,你准备备份它们到/var/mysqldb

  shell>mysqldump --tab=/var/mysqldb/ db

  其效果是在目录/var/mysqldb中生成4个文件,分别是tbl1.txttbl1.sqltbl2.txttbl2.sql

  2mysqldump实用程序时的身份验证的问题

  同其他客户机一样,你也必须提供一个MySQL数据库帐号用来导出数据库,如果你不是使用匿名用户的话,可能需要手工提供参数或者使用选项文件:

  如果这样:

  shell>mysql -u root –pmypass db_name>db_name.sql

  或者这样在选项文件中提供参数:

  [mysqldump]

  user=root

  password=mypass

  然后执行

  shell>mysqldump db_name>db_name.sql

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

  你可能要问,为什么这么麻烦呢,例如,这样使用命令行:

  shell>mysql -u root –p db_name>db_name.sql

  或者在选项文件中加入

  [mysqldump]

  user=root

  password

  然后执行命令行:

  shell>mysql db_name>db_name.sql

  你发现了什么?往常熟悉的Enter password:提示并没有出现,因为标准输出被重定向到文件db_name.sql中了,所以看不到往常的提示符,程序在等待你输入密码。在重定向的 情况下,再使用交互模式,就会有问题。在上面的情况下,你还可以直接输入密码。然后在文件db_name.sql文件的第一行看到:

  Enter password:#……..

  你可能说问题不大,但是mysqldump之所以把结果输出到标准输出,是为了重定向到其它程序的标准输入,这样有利于编写脚本。例如:

  用来自于一个数据库的信息充实另外一个MySQL数据库也是有用的:

  shell>mysqldump --opt database | mysql --host=remote-host -C database

  如果mysqldump仍运行在提示输入密码的交互模式下,该命令不会成功,但是如果mysql是否运行在提示输入密码的交互模式下,都是可以 的。

  如果在选项文件中的[client]或者[mysqldump]任何一段中指定了password选项,且不提供密码,即使,在另一段中有提供 密码的选项password=mypass,例如

  [client]

  user=root

  password

  [mysqldump]

  user=admin

  password=mypass

  那么mysqldump一定要你输入admin用户的密码:

  mysql>mysqldump db_name

  即使是这样使用命令行:

  mysql>mysqldump –u root –ppass1 db

  也是这样,不过要如果-u指定的用户的密码。

  其它使用选项文件的客户程序也是这样

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值