
- MySQL 基础
- MySQL - 首页
- MySQL - 简介
- MySQL - 功能
- MySQL - 版本
- MySQL - 变量
- MySQL - 安装
- MySQL - 管理
- MySQL - PHP 语法
- MySQL - Node.js 语法
- MySQL - Java 语法
- MySQL - Python 语法
- MySQL - 连接
- MySQL - Workbench
- MySQL 数据库
- MySQL - 创建数据库
- MySQL - 删除数据库
- MySQL - 选择数据库
- MySQL - 显示数据库
- MySQL - 复制数据库
- MySQL - 数据库导出
- MySQL - 数据库导入
- MySQL - 数据库信息
- MySQL 用户
- MySQL - 创建用户
- MySQL - 删除用户
- MySQL - 显示用户
- MySQL - 修改密码
- MySQL - 授予权限
- MySQL - 显示权限
- MySQL - 收回权限
- MySQL - 锁定用户账户
- MySQL - 解锁用户账户
- MySQL 表
- MySQL - 创建表
- MySQL - 显示表
- MySQL - 修改表
- MySQL - 重命名表
- MySQL - 克隆表
- MySQL - 截断表
- MySQL - 临时表
- MySQL - 修复表
- MySQL - 描述表
- MySQL - 添加/删除列
- MySQL - 显示列
- MySQL - 重命名列
- MySQL - 表锁定
- MySQL - 删除表
- MySQL - 派生表
- MySQL 查询
- MySQL - 查询
- MySQL - 约束
- MySQL - INSERT 查询
- MySQL - SELECT 查询
- MySQL - UPDATE 查询
- MySQL - DELETE 查询
- MySQL - REPLACE 查询
- MySQL - INSERT IGNORE
- MySQL - INSERT ON DUPLICATE KEY UPDATE
- MySQL - INSERT INTO SELECT
- 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 vs UNION ALL
- MySQL - MINUS 运算符
- MySQL - INTERSECT 运算符
- MySQL - INTERVAL 运算符
- MySQL 连接
- MySQL - 使用连接
- MySQL - INNER JOIN
- MySQL - LEFT JOIN
- MySQL - RIGHT JOIN
- MySQL - CROSS JOIN
- MySQL - FULL JOIN
- MySQL - 自连接
- MySQL - DELETE JOIN
- MySQL - UPDATE JOIN
- MySQL - UNION vs JOIN
- MySQL 触发器
- MySQL - 触发器
- MySQL - 创建触发器
- MySQL - 显示触发器
- MySQL - 删除触发器
- MySQL - BEFORE INSERT 触发器
- MySQL - AFTER INSERT 触发器
- MySQL - BEFORE UPDATE 触发器
- MySQL - AFTER UPDATE 触发器
- MySQL - BEFORE DELETE 触发器
- MySQL - AFTER DELETE 触发器
- MySQL 数据类型
- 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 - 聚合函数
- MySQL 其他概念
- MySQL - NULL 值
- MySQL - 事务
- MySQL - 使用序列
- MySQL - 处理重复项
- MySQL - SQL 注入
- MySQL - 子查询
- MySQL - 注释
- MySQL - 检查约束
- MySQL - 存储引擎
- MySQL - 将表导出到 CSV 文件
- MySQL - 将 CSV 文件导入数据库
- MySQL - UUID
- MySQL - 公共表表达式
- MySQL - ON DELETE CASCADE
- 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 - SHOW PROCESSLIST
- MySQL - 更改列类型
- MySQL - 重置自动递增
- MySQL - COALESCE() 函数
- MySQL 有用资源
- MySQL - 有用函数
- MySQL - 语句参考
- MySQL - 快速指南
- MySQL - 有用资源
- MySQL - 讨论
MySQL - 复制数据库
在现代,公司依靠数据库来存储关键信息,例如金融交易、客户资料和员工记录。定期维护数据库副本非常重要,因为电源浪涌和磁盘崩溃始终可能导致数据丢失。因此,定期备份数据库对于有效的数据管理至关重要。
在 MySQL 中复制数据库
在 MySQL 中,复制数据库包括创建一个现有数据库的精确副本,包括其架构和数据。这几乎类似于拥有数据库的备份。如有必要,务必确保复制后对原始数据库所做的任何更改也反映在复制的数据库中。
要创建数据库副本,SQL Server 提供了 **复制数据库** 语句。但是,MySQL 中没有此语句。因此,要创建数据库副本,我们需要手动将一个数据库的内容转储到另一个数据库。
复制数据库涉及以下三个步骤:
首先,我们需要创建一个新数据库。
然后,我们需要使用 **mysqldump** 导出原始数据库。
最后,将导出的数据导入新数据库。
示例
首先,让我们使用以下查询在 MySQL 服务器中创建一个数据库:
CREATE DATABASE testdb;
我们可以使用 **SHOW DATABASES** 语句验证数据库 **testdb** 是否已创建。
SHOW DATABASES;
如下所示,testdb 数据库已成功创建。
数据库 |
---|
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\testdb.sql
步骤 3 − 将“testdb.sql”文件的内容导入目标数据库(在本例中为“testdb_copy”)。
注意 − (<) 运算符用于将数据库从一个位置导入到另一个位置。
mysql -u root -p testdb_copy < D:\database_backup\testdb.sql
验证
要验证数据和数据库对象是否已导入到 testdb_copy 数据库中,首先,我们需要使用以下查询在MySQL 命令行客户端中使用当前数据库 −
USE testdb_copy;
如果testdb 的内容已成功复制到testdb_copy中,我们应该能够在表列表中找到客户表(该表是先前创建的)。
因此,让我们使用以下查询验证“testdb”数据库中的数据是否已复制到“testdb_copy”数据库中 −
SHOW TABLES;
如下所示,所有数据库对象和数据都已成功复制。
Tables_in_testdb |
---|
customers |
Learn MySQL in-depth with real-world projects through our MySQL certification course. Enroll and become a certified expert to boost your career.
无需 mysqldump 复制数据库
如果我们想在不使用 mysqldump 工具的情况下复制数据库,我们必须手动在目标数据库中创建每个表,并将当前数据库中存在的表中的所有数据复制到目标数据库中。这是一个重复的过程,需要对每个需要复制的表进行。
示例
让我们使用以下查询在 MySQL 服务器中创建一个新数据库 −
CREATE DATABASE Tutorials;
我们可以使用以下查询验证是否创建了数据库Tutorials −
SHOW DATABASES;
如下所示,'Tutorials' 数据库已成功创建。
数据库 |
---|
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;
数据库已创建。
数据库 |
---|
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 |