mysqldump数据库备份与还原参数详解

发布时间:2019-07-27编辑:脚本学堂
mysql数据库中使用mysqldump实现数据库备份与还原,介绍了mysqldump备份参数详解,学习下mysqldump命令的用法,感兴趣的朋友不要错过。

先说mysqldump备份:
 

mysqldump -u用户名 -p密码 -h主机 数据库 a -w “sql条件” –lock-all-tables > 路径

再看mysqldump还原:
 

mysqldump -u用户名 -p密码 -h主机 数据库 < 路径

mysqldump按条件导出:
 

mysqldump -u用户名 -p密码 -h主机 数据库 a –where “条件语句” –no-建表> 路径
mysqldump -uroot -p1234 dbname a –where “tag='88′” –no-create-info> c:a.sql

mysqldump按条件导入:
 

mysqldump -u用户名 -p密码 -h主机 数据库 < 路径

例子:
 

复制代码 代码示例:
mysql -uroot -p1234 db1 < c:a.txt
mysqldump导出表:
mysqldump -u用户名 -p密码 -h主机 数据库 表

例子:

复制代码 代码示例:
mysqldump -uroot -p sqlhk9 a –no-data


参数详解:
使用mysqldump
 

复制代码 代码示例:
mysqldump -u root -p your-new-password databasename [tablename] > db.sql

比较大的表需要用优化的dump以节省内存:
 

复制代码 代码示例:
mysqldump --opt database > backup-file.sql

mysqldump工具有大量的选项,部分选项如下表:
  选项/Option 作用/Action Performed
  --add-drop-table
  这个选项将会在每一个表的前面加上DROP TABLE IF EXISTS语句,这样可以保证导回mysql数据库的时候不会出错,因为每次导回的时候,都会首先检查表是否存在,存在就删除
  --add-locks
  这个选项会在INSERT语句中捆上一个LOCK TABLE和UNLOCK TABLE语句。这就防止在这些记录被再次导入数据库时其他用户对表进行的操作
  
  -c or - complete_insert
  这个选项使得mysqldump命令给每一个产生INSERT语句加上列(field)的名字。当把数据导出导另外一个数据库时这个选项很有用。
  --delayed-insert 在INSERT命令中加入DELAY选项
  -F or -flush-logs 使用这个选项,在执行导出之前将会刷新MySQL服务器的log.
  -f or -force 使用这个选项,即使有错误发生,仍然继续导出
  --full 这个选项把附加信息也加到CREATE TABLE的语句中
  -l or -lock-tables 使用这个选项,导出表的时候服务器将会给表加锁。
  -t or -no-create- info
  这个选项使的mysqldump命令不创建CREATE TABLE语句,这个选项在您只需要数据而不需要DDL(数据库定义语句)时很方便。
  
  -d or -no-data 这个选项使的mysqldump命令不创建INSERT语句。

在您只需要DDL语句时,可以使用这个选项。
  --opt 此选项将打开所有会提高文件导出速度和创造一个可以更快导入的文件的选项。
  -q or -quick 这个选项使得MySQL不会把整个导出的内容读入内存再执行导出,而是在读到的时候就写入导文件中。
  -T path or -tab = path 这个选项将会创建两个文件,一个文件包含DDL语句或者表创建语句,另一个文件包含数据。DDL文件被命名为table_name.sql,数据文件被命名为table_name.txt.路径名是存放这两个文件的目录。目录必须已经存在,并且命令的使用者有对文件的特权。
  
  -w "WHERE Clause" or -where = "Where clause "