mysqldump备份数据库:Couldn't find table:";"是怎么回事

MySQL数据库备份按照格式可以分为两大类:

文本格式的备份:这类备份是通过使用mysqldump程序把数据表内容写到转储文件二得到的,内容主要是由CREATE TABLEINSERT两种SQL语句构成,把转储文件重新加载到MySQL服务器上就可以恢复有关的数据表。

二进制备份:这类备份是通过直接复制那些包含着数据表内容的文件而得到的。制作这类备份的具体办法有许多种,诸如mysqlhotcopycptarrsync之类的程序都可以用来数据库制作二进制备份。

mysqldump程序生成的内容是SQL语句的文本文件,很方面移植,平时用的就是这种方法。

mysqldump程序有许多选项。一下几个选项是比较常用的。

①、通常在mysqldump命令行给出一个数据库名,然后可以在它后面再选择性地给出几个数据表名。如果想一次转储多个数据库,就要使用--databases选项。mysqldump将把你在命令行上给出的名字全部解释为数据库名,并依次转储这些数据库里的所有数据表。如果想转储所有的数据库,可以使用--all-databases选项,此时不需要给出任何数据库名或数据表名参数。这两个参数会在每个数据库输出前插入必要的CREATE

②、在默认情况下,mysqldump程序将同时备份数据表的结构(CREATE

③、可以使用--opt选择进行备份优化。默认是启动的,如果不需要,可以shiyong--skip-opt选项禁用。

--opt选项会把正在备份的数据表全部锁定,不让其他人修改。因此在确认无用户需要操作数据库的时候进行备份。

TABLE语句之爱情你加上一条DROP TABLE IF EXISTS语句。这样你在加载的时候,如果数据表已经存在,也不会发生错误。

⑤、在备份InnoDBFalcon数据表的时候,最好使用--single-transaction选项把备份操作放在一个事务里执行,这可以确保得到一个稳定的备份。

⑥、如果数据库包含着存储例程、触发器和事件,可以使用--routing--triggers--events选项明确地把它们包括到备份文件里。注意,这个三个选项分别开始于MYSQL5.0135.0.115.1.8版本,如果是在此之前的版本,不支持。同时这几个选项还各有一个--skip形式(例如--skip-triggers)用来禁止备份指定的对象。

在默认是情况下,只有触发器将被包括在备份输入里,存储例程和事件不进入存储。

3.导出一个数据库结构

  然后使用source命令,后面参数为脚本文件(如这里用到的.sql)

  由于mysqldump导出的是完整的SQL语句,所以用mysql客户程序很容易就能把数据导入了:


dump表结构及表数据

//dump指定表中的数据

我要回帖

更多关于 mysqldump 的文章

 

随机推荐