首页 > 数据库 > MySQL > 正文

mysqldump数据库备份参数详解

2024-07-24 12:47:27
字体:
来源:转载
供稿:网友

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 此选项将打开所有会提高文件导出速度和创造一个可以更快导入的文件的选项。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表