使用mysqldump备份数据库时如何包含创建数据库语句

87

我正在将文件移动到另一台计算机,想要做的一件事是将MySQL数据库中的数据转移。 我想将数据库转储为.sql文件,但也希望在文件中包含create database db_name命令,这样我只需导入文件到mysql,而无需手动创建数据库。是否有方法可以做到这一点?

4个回答

107
默认情况下,mysqldump 总是在转储文件的开头创建 CREATE DATABASE IF NOT EXISTS db_name; 语句。

[编辑] 关于 mysqldump 文件及其选项的一些说明:

--all-databases, -A

转储所有数据库中的所有表。这与使用 --databases 选项并在命令行上命名所有数据库相同。

--add-drop-database

在每个 CREATE DATABASE 语句之前添加一个 DROP DATABASE 语句。此选项通常与 --all-databases--databases 选项一起使用,因为除非指定了其中一个选项,否则不会编写 CREATE DATABASE 语句。

--databases, -B

转储几个数据库。通常,mysqldump 将命令行上的第一个名称参数视为数据库名称,后面的名称视为表名称。使用此选项时,它将所有名称参数视为数据库名称。在每个新数据库之前,输出包括 CREATE DATABASEUSE 语句。

--no-create-db, -n

如果给出了 --databases--all-databases 选项,则此选项抑制否则包含在输出中的 CREATE DATABASE 语句。

一段时间以前,实际上有类似的问题询问如何不在文件开头添加此类语句 (对于 XML 文件)。 那个问题的链接在这里

所以回答你的问题:

  • 如果您要转储一个数据库, 您应该使用 --databases db_name 选项。这将创建一个包括 CREATE DATABASE 语句和您指定的数据库名称的转储文件。
  • 如果您要同时转储多个数据库, 您可以使用 --databases db1 db2 db3 选项。这将创建一个包括所有指定数据库的 CREATE DATABASE 语句的转储文件。
在你的 mysqldump 语句中使用选项 --add-drop-database。如果你有多个数据库需要导出,应该使用选项 --databases--all-databases,这将自动添加 CREATE DATABASE 语法。更多信息请参考 MySQL 参考手册

2
这就是我的问题所在。我没有使用--databases或--all-databases。我只是输入了数据库名称,这不会创建如果存在则删除数据库并创建数据库的命令行。 - Vince
是的,在只有一个数据库的情况下,添加 --add-drop-database 选项,一切都应该没问题。但请记住,如果计算机中存在该数据库,则导入转储文件将实际删除该数据库及其包含在内的所有内容。 - GregD
5
这是哪个版本的?mysqldump Ver 10.11 Distrib 5.0.51a,适用于debian-linux-gnu (i486)。mysqldump --add-drop-database test | grep DROP 只会输出test数据库的DROP TABLE语句,要获取注释的DROP DATABASE IF EXISTS test,需要在命令中加上--databases选项。 - jla
2
有趣的事实:--tables选项将再次删除CREATE DATABASE语句,即使您已经使用了--databases。在我的情况下,使用mysqldump Ver 10.18 Distrib 10.5.8-MariaDB,for osx10.15(x86_64)发生了这种情况。 - Richard Kiefer
1
@RichardKiefer 我也遇到了同样的问题,根据文档的说明,使用 --tables 选项会完全覆盖 --databases 选项。 - jlaitio
显示剩余2条评论

41

最简单的解决方案是使用选项-B或--databases。然后,CREATE database命令将出现在输出文件中。 例如:

-B或--databases选项

mysqldump -uuser -ppassword -d -B --events --routines --triggers database_example > database_example.sql

这是一个转储文件的头部:

-- MySQL dump 10.13  Distrib 5.5.36-34.2, for Linux (x86_64)
--
-- Host: localhost    Database: database_example
-- ------------------------------------------------------
-- Server version       5.5.36-34.2-log

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Current Database: `database_example`
--

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `database_example` /*!40100 DEFAULT CHARACTER SET utf8 */;

4
以下是如何转储数据库(仅包含模式)的方法:

mysqldump -u root -p"passwd" --no-data --add-drop-database --databases my_db_name | sed 's#/[*]!40000 DROP DATABASE IF EXISTS my_db_name;#' >my_db_name.sql

如果您还想要数据,请删除--no-data选项。

4
--databases, -B 转储多个数据库。通常,mysqldump将命令行上的第一个名称参数视为数据库名称,后续名称视为表名。使用此选项,它将所有名称参数视为数据库名称。在每个新数据库之前,输出中包含CREATE DATABASE和USE语句。

https://dev.mysql.com/doc/refman/8.0/en/mysqldump.html#option_mysqldump_databases


基本上,在单个数据库前面使用-B,可以有CREATE DATABASE语句。

  • 简短的: mysqldump -B <数据库名>

  • 长的:mysqldump --databases <数据库名>


如果使用MariaDB,还可查看MariaDB的mysqldump--system=user选项以保留用户授权。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接