MySQL 8 教程

MySQL - 主页 MySQL - 简介 MySQL - 功能 MySQL - 版本 MySQL - 变量 MySQL - 安装 MySQL - 管理 MySQL - PHP 语法 MySQL - Node.js 语法 MySQL - Java 语法 MySQL - Python 语法 MySQL - 连接 MySQL - Workbench

MySQL 8 数据库

MySQL - 创建数据库 MySQL - 删除数据库 MySQL - 选择数据库 MySQL - 显示数据库 MySQL - 复制数据库 MySQL - 数据库导出 MySQL - 数据库导入 MySQL - 数据库信息

MySQL 8 用户

MySQL - 创建用户 MySQL - 删除用户 MySQL - 显示用户 MySQL - 更改密码 MySQL - 授予权限 MySQL - 显示权限 MySQL - 撤销权限 MySQL - 锁定用户账户 MySQL - 解锁用户账户

MySQL 8 表

MySQL - 创建表 MySQL - 显示表 MySQL - 修改表 MySQL - 重命名表 MySQL - 克隆表 MySQL - 截断表 MySQL - 临时表 MySQL - 修复表 MySQL - 描述表 MySQL - 添加/删除列 MySQL - 显示列 MySQL - 重命名列 MySQL - 表锁定 MySQL - 删除表 MySQL - 派生表

MySQL 8 查询

MySQL - 查询 MySQL - 约束 MySQL - INSERT 插入查询 MySQL - SELECT 查询 MySQL - UPDATE 更新查询 MySQL - DELETE删除查询 MySQL - REPLACE 替换查询 MySQL - 忽略插入 MySQL - 重复键更新时插入 MySQL - 插入到另一个表语句

MySQL 8 视图

MySQL - 创建视图 MySQL - 更新视图 MySQL - 删除视图 MySQL - 重命名视图

MySQL 8 索引

MySQL - 索引 MySQL - 创建索引 MySQL - 删除索引 MySQL - 显示索引 MySQL - 唯一索引 MySQL - 聚集索引 MySQL - 非聚集索引

MySQL 运算符和子句

MySQL - Where 子句 MySQL - Limit 子句 MySQL - Distinct 子句 MySQL - Order By 子句 MySQL - Group By 子句 MySQL - Having 子句 MySQL - AND 运算符 MySQL - OR 或运算符 MySQL - LIKE 运算符 MySQL - IN 运算符 MySQL - ANY 运算符 MySQL - Exists 运算符 MySQL - NOT 运算符 MySQL - NOT EQUAL 运算符 MySQL - IS NULL 运算符 MySQL - IS NOT NULL 运算符 MySQL - Between 运算符 MySQL - UNION 运算符 MySQL - UNION 与 UNION ALL MySQL - MINUS 运算符 MySQL - INTERSECT 运算符 MySQL - INTERVAL 运算符

MySQL 连接

MySQL - 使用连接 MySQL - Inner Join 内连接 MySQL - LEFT JOIN 左连接 MySQL - RIGHT JOIN 右连接 MySQL - CROSS JOIN 交叉连接 MySQL - 全连接 MySQL - 自连接 MySQL - Delete Join 删除连接 MySQL - UPDATE JOIN 更新连接 MySQL - 联合 vs 连接

MySQL 键

MySQL - UNIQUE 唯一键 MySQL - PRIMARY KEY 主键 MySQL - FOREIGN KEY 外键 MySQL - 复合键 MySQL - 备用键

MySQL 触发器

MySQL - 触发器 MySQL - 创建触发器 MySQL - 显示触发器 MySQL - 删除触发器 MySQL - 插入前触发器 MySQL - 插入后触发器 MySQL - 更新前触发器 MySQL - 更新后触发器 MySQL - 删除前触发器 MySQL - 删除后触发器

MySQL 8 数据类型

MySQL - 数据类型 MySQL - VARCHAR MySQL - BOOLEAN MySQL - ENUM 枚举 MySQL - DECIMAL 十进制 MySQL - INT 整数 MySQL - FLOAT 浮点数 MySQL - BIT 位 MySQL - TINYINT 微小整数 MySQL - BLOB 二进制大对象 MySQL - SET 集合

MySQL 正则表达式

MySQL - 正则表达式 MySQL - RLIKE 运算符 MySQL - NOT LIKE 运算符 MySQL - NOT REGEXP 运算符 MySQL - regexp_instr() 函数 MySQL - regexp_like() 函数 MySQL - regexp_replace() 函数 MySQL - regexp_substr() 函数

MySQL 全文搜索

MySQL - 全文搜索 MySQL - 自然语言全文搜索 MySQL - 布尔全文搜索 MySQL - 查询扩展全文搜索 MySQL - ngram 全文解析器

MySQL8 函数和运算符

MySQL - 日期和时间函数 MySQL - 算术运算符 MySQL - 数字函数 MySQL - 字符串函数 MySQL - 聚合函数

MySQL 8 其他概念

MySQL - NULL 值 MySQL - 事务 MySQL - 序列 MySQL - 处理重复项 MySQL - SQL 注入 MySQL - 子查询 MySQL - 注释 MySQL - 检查约束 MySQL - 存储引擎 MySQL - 将表导出为 CSV 文件 MySQL - 将 CSV 文件导入数据库 MySQL - UUID MySQL - 通用表表达式 MySQL - 级联删除 MySQL - Upsert 操作 MySQL - 水平分区 MySQL - 垂直分区 MySQL - 游标 MySQL - 存储函数 MySQL - SIGNAL 异常处理 MySQL - RESIGNAL 异常处理 MySQL - 字符集 MySQL - 排序规则 MySQL - 通配符 MySQL - 别名 MySQL - ROLLUP 超级聚合 MySQL - 当前日期 MySQL - 字面量 MySQL - 存储过程 MySQL - EXPLAIN 语句 MySQL - JSON MySQL - 标准差 MySQL - 查找重复记录 MySQL - 删除重复记录 MySQL - 选择随机记录 MySQL - 显示进程列表 MySQL - 更改列类型 MySQL - 重置自动增量 MySQL - Coalesce() 函数

MySQL 8 实用资源

MySQL - 实用函数 MySQL - 语句参考 MySQL - 快速指南 MySQL - 实用资源 MySQL - 讨论


MySQL - 复制数据库

如今,公司依靠数据库来存储关键信息,例如财务交易、客户资料和员工记录。定期维护数据库副本非常重要,因为电源浪涌和磁盘崩溃随时都有可能导致数据丢失。因此,定期备份数据库对于有效的数据管理至关重要。

在 MySQL 中复制数据库

在 MySQL 中,复制数据库涉及创建现有数据库的精确副本,包括其架构和数据。这几乎类似于数据库的备份。重要的是,确保在复制后对原始数据库所做的任何更改也反映在复制的数据库中(如有必要)。

为了创建数据库副本,SQL Server 提供了 Copy Database 语句。但是,MySQL 不提供该语句。因此,要创建数据库副本,我们需要手动将一个数据库的内容转储到另一个数据库。

复制数据库涉及以下三个步骤 -

  • 首先,我们需要创建一个新的数据库。

  • 然后,我们需要使用 mysqldump 导出原始数据库。

  • 最后,将导出的数据导入新数据库。

示例

首先,让我们使用以下查询在 MySQL 服务器中创建一个数据库 -

CREATE DATABASE testdb;

我们可以使用 SHOW DATABASES 语句来验证数据库 testdb 是否已创建。

SHOW DATABASES;

如以下输出所示,testdb 数据库已成功创建。

Database
information_schema
mysql
performance_schema
testdb

数据库创建成功后,我们需要使用 USE 语句将当前数据库更改为 'testdb',这样我们执行的任何操作(例如创建表)都将存储在此数据库中。

USE testdb;

现在,让我们使用 CREATE 查询创建一个名为 CUSTOMERS 的表,如下所示 -

CREATE TABLE CUSTOMERS (
   ID INT AUTO_INCREMENT,
   NAME VARCHAR(20) NOT NULL,
   AGE INT NOT NULL,
   ADDRESS CHAR (25),
   SALARY DECIMAL (18, 2),
   PRIMARY KEY (ID)
);

以下查询将 7 条记录插入到上面创建的表中 -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) VALUES 
(1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ),
(2, 'Khilan', 25, 'Delhi', 1500.00 ),
(3, 'Kaushik', 23, 'Kota', 2000.00 ),
(4, 'Chaitali', 25, 'Mumbai', 6500.00 ),
(5, 'Hardik', 27, 'Bhopal', 8500.00 ),
(6, 'Komal', 22, 'Hyderabad', 4500.00 ),
(7, 'Muffy', 24, 'Indore', 10000.00 );

使用以下查询,我们可以验证表 CUSTOMERS 是否在 'testdb' 数据库中创建 -

SHOW TABLES;

该表已在 testdb 数据库中成功创建。

Tables_in_testdb
customers

创建副本数据库(手动)

如前所述,在 MySQL 中,要创建现有数据库的副本,我们需要创建一个单独的数据库,并将其内容手动转储到新创建的数据库中。

以下语句创建一个名为 testdb_copy 的数据库(我们需要将上面创建的 testdb 数据库的内容复制到该数据库)。

CREATE DATABASE testdb_copy;

一旦源数据库 (testdb) 和目标数据库 (testdb_copy) 都准备就绪,我们需要按照以下步骤手动将数据从一个数据库复制到另一个数据库。

步骤 1 − 打开命令提示符,浏览 MySQL 服务器的 bin 文件夹。例如,我们将 MySQL 安装在 C\ Program Files 目录中,因此以下命令将带我们进入 bin 文件夹 -

C:\> CD C:\Program Files\MySQL\MySQL Server 8.0\bin

步骤 2 - 使用 mysqldump 工具,我们可以将数据库对象和数据复制到 .sql 文件中。这里,我们将 testdb 数据库的内容导出到名为 "testdb.sql" 的文件,该文件位于"D:\Database_backup"。

注意 − (>) 运算符用于将数据库从一个位置导出到另一个位置。

mysqldump -u root -p testdb > D:\database_backup estdb.sql

步骤 3 − 将"testdb.sql"文件的内容导入目标数据库(在本例中为 "testdb_copy")。

注意 − (<) 运算符用于将数据库从一个位置导入到另一个位置。

mysql -u root -p testdb_copy

验证

要验证数据和数据库对象是否已导入 testdb_copy 数据库,首先,我们需要在 MySQL 命令行客户端 中使用以下查询来使用当前数据库 -

USE testdb_copy;

如果 testdb 的内容成功复制到 testdb_copy,我们应该能够在表列表(之前创建的)中找到客户表。

因此,让我们使用以下查询来验证"testdb"数据库中的数据是否已复制到"testdb_copy"数据库 -

SHOW TABLES;

正如我们在下面的列表中看到的,所有数据库对象和数据都已成功复制。

Tables_in_testdb
customers

不使用 MySQLdump 复制数据库

如果我们想在不使用 mysqldump 工具的情况下复制数据库,则必须手动在目标数据库中创建每个表,并复制当前数据库中所有表的数据。这是一个重复的过程,每个需要复制的表都需要重复执行。

示例

让我们使用以下查询在 MySQL 服务器中创建一个新的数据库 -

CREATE DATABASE Tutorials;

我们可以使用以下查询来验证数据库 Tutorials 是否已创建 -

SHOW DATABASES;

正如我们在下面看到的输出,"Tutorials"数据库已成功创建。

Database
information_schema
mysql
performance_schema
tutorials

现在,我们将当前数据库切换到 Tutorials,这样我们执行的任何操作(例如创建表)都将存储在此数据库中。

USE Tutorials;

切换后,使用以下查询创建一个名为 CUSTOMERS 的表 -

CREATE TABLE CUSTOMERS (
   ID INT AUTO_INCREMENT,
   NAME VARCHAR(20) NOT NULL,
   AGE INT NOT NULL,
   ADDRESS CHAR (25),
   SALARY DECIMAL (18, 2),
   PRIMARY KEY (ID)
);

在这里,我们使用下面的 INSERT INTO 语句将一些记录插入表中 -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) VALUES 
(1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ),
(2, 'Khilan', 25, 'Delhi', 1500.00 ),
(3, 'Kaushik', 23, 'Kota', 2000.00 ),
(4, 'Chaitali', 25, 'Mumbai', 6500.00 ),
(5, 'Hardik', 27, 'Bhopal', 8500.00 ),
(6, 'Komal', 22, 'Hyderabad', 4500.00 ),
(7, 'Muffy', 24, 'Indore', 10000.00 );

使用以下查询,让我们创建另一个数据库 Tutorials_copy,我们将复制 Tutorials 数据库的所有数据对象和数据。

CREATE DATABASE Tutorials_copy;

我们可以使用以下查询来验证数据库 Tutorials_copy 是否已创建 -

SHOW DATABASES;

数据库已创建。

Database
information_schema
mysql
performance_schema
tutorials
tutorials_copy

现在,使用以下查询将当前数据库切换到"tutorials_copy" -

USE Tutorials_copy;

在这里,我们在"Tutorials_copy"数据库中创建一个名为"CUSTOMERS"的空表,其模式与"Tutorials"数据库中的原始"CUSTOMERS"表相同 -

CREATE TABLE Tutorials_copy.customers LIKE Tutorials.customers;

此查询将"Tutorials"数据库中原始"customers"表的所有数据插入到"tutorials_copy"数据库中新的"customers"表中。

INSERT Tutorials_copy.customers SELECT * FROM Tutorials.customers;

我们可以验证"Tutorials"数据库中的数据库对象和数据是否已复制到"Tutorials_copy"数据库。

SHOW TABLES;

输出

如下面的列表所示,该表已成功复制 -

Tables_in_tutorials_copy
customers

我们再检索一下"Tutorials_copy"数据库中 CUSTOMERS 表的记录,以验证这些记录是否已被复制 -

Select * from CUSTOMERS;

正如我们在下方"Tutorials_copy"数据库中看到的 CUSTOMERS 表所示,记录已成功复制 -

ID NAME AGE ADDRESS SALARY
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00
3 Kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00
5 Hardik 27 Bhopal 8500.00
6 Komal 22 Hyderabad 4500.00
7 Muffy 24 Indore 10000.00