MySQL数据库的备份与还原操作方法

 更新时间:2022年06月08日 08:53:32   作者:彭世瑜  
这篇文章主要介绍了MySQL数据库的备份与还原操作方法,文章围绕主题展开详细的内容加入,具有一定的参考价值,需要的小伙伴可以参考一下

1、数据库备份

备份的结果都是SQL指令

mysqldump:专门用于备份SQL的客户端

SQL备份:表结构 + 数据

缺点:

  • 会产生的备份文件特别大
  • 不适合特大型数据备份
  • 不适合数据变更频繁的数据库备份

基本语法:

> mysqldump -hPup 数据库名字 [表1 [表2]] > 备份文件地址

备份可以有3种形式:

  • 整库备份 只需太提供数据库名字
  • 单表备份 数据库后跟一张表
  • 多表备份 数据库后跟多张表

示例:

# 整库备份
> mysqldump -hlocalhost -P3306 -uroot -p123456 mydatabase > mydatabase.bak.sql

# 单表备份
> mysqldump -hlocalhost -P3306 -uroot -p123456 mydatabase my_student > mydatabase.my_student.bak.sql
# 多表备份
> mysqldump -hlocalhost -P3306 -uroot -p123456 mydatabase my_student my_class > mydatabase.my_student__my_class.bak.sql

备份文件内容:

-- 删除已存在的表
DROP TABLE IF EXISTS `my_student`;
-- 创建表结构
SET character_set_client = utf8mb4 ;
CREATE TABLE `my_student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL,
  `class_id` int(11) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `gender` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
-- 插入数据
LOCK TABLES `my_student` WRITE;
INSERT INTO `my_student` VALUES (1,'刘备',1,18,2),(2,'李四',1,19,1),(3,'王五',2,20,2),(4,'张飞',2,21,1),(5,'关羽',NULL,22,2),(6,'曹操',1,20,NULL);
UNLOCK TABLES;

2、数据还原

mysqldump备份的数据文件,没有关于数据库本身的操作,都是针对表级别的操作,当进行数据还原,必须指定数据库

方式一:mysql客户端

# 不用登录,直接操作
> mysql -hPup 数据库 < SQL文件位置
mysql -hlocalhost -P3306 -uroot -p123456 mydatabase2 < mydatabase.bak.sql

方式二:SQL指令导入

-- 首先进入到对应的数据库
mysql> source SQL文件位置
source mydatabase.bak.sql;

方式三:手动复制粘贴(不推荐)

打开备份文件,复制所有SQL指令,粘贴到mysql命令行中执行

到此这篇关于MySQL数据库数据库备份与还原的文章就介绍到这了,更多相关MySQL数据备份还原内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql临时变量的使用

    mysql临时变量的使用

    这篇文章主要介绍了mysql临时变量的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • python中的mysql数据库LIKE操作符详解

    python中的mysql数据库LIKE操作符详解

    LIKE操作符用于在WHERE子句中搜索列中的指定模式,like操作符的语法在文章开头也给大家提到,通过两种示例代码给大家介绍python中的mysql数据库LIKE操作符知识,感兴趣的朋友跟随小编一起看看吧
    2021-07-07
  • Linux连接mysql报错:Access denied for user ‘root’@‘localhost’(using password: YES)的解决方法

    Linux连接mysql报错:Access denied for user ‘root’@‘localhost’(usi

    这篇文章主要给大家介绍了关于Linux连接mysql数据库报错:Access denied for user ’root‘@’localhost‘(using password: YES)的解决方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2018-01-01
  • MySQL子查询的使用详解上篇

    MySQL子查询的使用详解上篇

    子查询是在查询语句里面再嵌套一个查询,这是因为我们在提取数据的时候有很多不知道的数据产生了依赖关系。本文为大家总结了一下MySQL数据库子查询语法规则,感兴趣的可以了解一下
    2022-08-08
  • MySQL中字符串索引对update的影响分析

    MySQL中字符串索引对update的影响分析

    这篇文章主要介绍了MySQL中字符串索引对update的影响,结合实例形式分析了添加索引操作对于update语句的性能所造成的影响,需要的朋友可以参考下
    2016-04-04
  • MySQL表中添加数据的方法

    MySQL表中添加数据的方法

    这篇文章主要介绍了MySQL表中添加数据的方法,本文通过sql语句给大家详细讲解,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • prometheus监控MySQL并实现可视化的操作详解

    prometheus监控MySQL并实现可视化的操作详解

    mysqld_exporter 是一个用于监控 MySQL 服务器的开源工具,它是由 Prometheus 社区维护的一个官方 Exporter,本文给大家介绍了prometheus监控MySQL并实现可视化的操作,文中通过代码和图文讲解的非常详细,需要的朋友可以参考下
    2024-04-04
  • 浅谈MySQL安装starting the server失败的解决办法

    浅谈MySQL安装starting the server失败的解决办法

    如果电脑是不是第一次安装MySQL,一般会出现报错情况,starting the server失败,通常是因为上次安装的该软件未清除干净,本文就详细的介绍一下解决方法,感兴趣的可以了解一下
    2021-09-09
  • MySQL空间函数ST_Distance_Sphere()的使用方式

    MySQL空间函数ST_Distance_Sphere()的使用方式

    这篇文章主要介绍了MySQL空间函数ST_Distance_Sphere()的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 打开和关闭mysql服务的两种实现方法

    打开和关闭mysql服务的两种实现方法

    这篇文章主要介绍了打开和关闭mysql服务的两种实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07

最新评论