具有 create 数据库行的 mysqldump

我正在将我的文件转移到另一台计算机上,我想做的一件事是将数据传输到我的 MySQL 数据库中。我想把数据库转到。Sql 文件,而且在文件中包含创建数据库 db _ name,这样我只需要将文件导入 mysql,而不必手动创建数据库。有办法吗?

124435 次浏览

默认情况下,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将命令行上的第一个 name 参数作为数据库名称,将以下名称作为表名称。使用此选项,它将所有名称参数视为数据库名称。CREATE DATABASEUSE语句包含在每个新数据库之前的输出中。

--no-create-db-n

如果给定 --databases--all-databases选项,则此选项将取消输出中包含的 CREATE DATABASE语句。

一段时间以前,实际上有一个类似的问题,即在文件的开头(对于 XML 文件)没有这样的语句。链接到这个问题 在这里

回答你的问题:

  • 如果要转储一个数据库,则应该使用 mysqldump语句中的 --add-drop-database选项。
  • 如果要转储多个数据库,则应使用该选项 将添加 --databases--all-databasesCREATE DATABASE语法 自然而然地

详情请浏览 MySQL 参考手册

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

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 */;

下面是如何转储数据库(只使用模式) :

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选项。

- 数据库-B

转储多个数据库。通常,mysqldump 处理名字 命令行上的参数作为数据库名称,以下名称作为 使用此选项,它将所有名称参数视为 中包含 CREATE DATABASE 和 USE 语句 每个新数据库之前的输出

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


基本上使用 -B在(单个)数据库前面有 create database语句。

  • 简称: mysqldump -B <database>

  • 长: mysqldump --databases <database>


如果在 MariaDB 上,也请参阅 MariaDB 的 Mysqldump--system=user选项,以保留用户授权。