MySQL之逻辑备份与恢复

news2025/1/12 1:57:45

逻辑备份简介:

备份的是建表、建库、插入等操作所执行SQL语句,适用于中小型数据库,效率相对较低。

本质:导出的是SQL语句文件

优点:不论是什么存储引擎,都可以用mysqldump备成SQL语句

缺点:速度较慢,导入时可能会出现格式不兼容的突发情况,无法做增量备份和累计增量备份。

提供三种级别的备份,表级,库级和全库级

逻辑备份: 备份的是建表、建库、插入等操作所执行SQL语句(DDL DML DCL),适用于中小型数据库,效率相对较低。

数据一致,服务可用。:如何保证数据一致,在备份的时候进行锁表会自动锁表。锁住之后在备份

本身为客户端工具:
远程备份语法: # mysqldump  -h 服务器  -u用户名  -p密码   数据库名  > 备份文件.sql
本地备份语法: # mysqldump  -u用户名  -p密码   数据库名  > 备份文件.sql

***-A, --all-databases*** \
备份所有库

**-B**, **--databases bbs test mysql** 备份多个数据库

**--no-data,-d**\
不导出任何数据,只导出数据库表结构。

MYSQL逻辑备份

1.备份所有的库

 [root@new opt]# mysqldump -uroot -pzyq123 -A > alldatabases.sql

语法: mysqldump   -uroot   -p'密码'    -A   >   文件名 

-A就是所有库,也可以是  -all --databases

此命令是将结果都输出重定向到一个文件当中,不然全部输出到终端屏幕不好看

[root@new opt]# ls
alldatabases.sql

查看文件内容 

1.2 备份部分库

[root@new opt]# mysqldump -uroot -pzyq123 -B company mysql > company.mysql-`date +%F`.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@new opt]# ls
alldatabases.sql  company.mysql-2023-09-28.sql

语法: mysqldump  -uroot   -p'密码'  -B 库名  库名   > 文件名

出现[Warning] Using a password on the command line interface can be insecure.

意思是在命令行界面上使用密码可能不安全。 正常现象。

输出重定向的时候在文件名中加上 `date +%F`     就可以在之后备份回复的时候知道这是什么时候备份的文件 。

1.2.1 备份部分库2

[root@new opt]# mysqldump -uroot -pzyq123 --databases db1 mysql > db1-mysql.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.

[root@new opt]# ls
alldatabases.sql  company.mysql-2023-09-28.sql  db1-mysql.sql

1.3 备份哪个库的哪个表(表结构+内容)

mysql> use db1;
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| hh            |
| idol          |
+---------------+

备份db1库下的hh表
[root@new ~]# mysqldump -uroot -pzyq123 db1 hh > db1-hh.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@new ~]# ls
db1-hh.sql

语法: mysqldump -uroot -p‘密码’  库名  表名  

如果想备份该库下 多个表,直接在库名后面+表名字即可  用空格隔开 不需要加逗号。

1.4 备份表结构

[root@new ~]# mysqldump -uroot -pzyq123 -d  school student > school-student.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@new ~]# ls
db1-hh.sql  school-student.sql

语法: mysqldump    -uroot   -p‘密码’   -d  库名 表名 

我的记法是:在MySQL里 查看表的结构是desc  因此这里备份表的结构就是 -d

1.5 备份表的数据

mysql> show variables like 'secure%';
+------------------+-----------------------+
| Variable_name    | Value                 |
+------------------+-----------------------+
| secure_auth      | ON                    |
| secure_file_priv | /var/lib/mysql-files/ |
+------------------+-----------------------+

 mysql> select * from mysql.user into outfile '/var/lib/mysql-files/a.txt';
Query OK, 6 rows affected (0.00 sec)
[root@new mysql-files]# pwd
/var/lib/mysql-files
[root@new mysql-files]# ls
a.txt

备份数据库表的数据是需要到MySQL里面操作的

语法: mysql >  select * from mysql.user  into outfile  '/var/lib/mysql-files/新文件名字'

在Linux的MySQL中,使用"show variables like ‘secure%’“命令可以查看与安全性相关的变量配置。根据引用和引用的内容,secure_auth参数表示是否启用安全认证,secure_file_priv参数表示导出数据时的安全文件路径。在引用和引用中的例子中,secure_auth的值为OFF,secure_file_priv的值分别为”/"和NULL。

1.6 可以将备份表的数据导出到本地系统,以excel的形式查看

以刚才的a.txt为例

[root@new mysql-files]# sz a.txt.sql 

rz是将包上传到服务器,sz是将包 文件下载到本地
如果没有该命令  则下载
 # yum -y  install lrzsz

下载到本地用excel打开,将文件的格式改成以.xlsx或者.xls的形式

打开以后的样子如下:

数据库恢复

2.1 恢复数据库,命令行恢复

# 首先将数据库备份
[root@new opt]# mysqldump -uroot -pzyq123 --databases db1 > db1.sql

#删除数据库db1
mysql> drop database db1;
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| company            |
| mysql              |
| performance_schema |
| school             |
| sys                |
+--------------------+

#恢复数据库!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
[root@new opt]# mysql -uroot -p'zyq123' < db1.sql 

#查看是否恢复成功
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| company            |
| db1                |
| mysql              |
| performance_schema |
| school             |
| sys                |
+--------------------+


mysql> use db1;
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| hh            |
| idol          |
+---------------+
2 rows in set (0.00 sec)

语法: mysql -uroot  -p'密码'  < 备份数据库的文件的路径

2.1.2数据库恢复之MySQL里恢复

mysql> source /opt/db1.sql;     #恢复数据库!!!!
Query OK, 0 rows affected (0.00 sec)
...
Query OK, 0 rows affected, 1 warning (0.00 sec)
...
Database changed
...
Query OK, 0 rows affected, 1 warning (0.00 sec)
...
Query OK, 0 rows affected (0.00 sec)

mysql> show databases;     #查看是否恢复成功
+--------------------+
| Database           |
+--------------------+
| information_schema |
| company            |
| db1                |
| mysql              |
| performance_schema |
| school             |
| sys                |
+--------------------+
7 rows in set (0.00 sec)

语法:mysql >  source  +备份数据库的路径

2.2 恢复表

#首先删除db1库的一个hh表
mysql> drop table hh;
mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| idol          |
+---------------+

[root@new opt]# mysql -uroot -p'zyq123' db1 < db1.sql    #恢复表


mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| hh            |
| idol          |
+---------------+
2 rows in set (0.00 sec)

语法:mysql  -uroot   -p'密码'  库名  < 存放该表的库所在路径

2.3 恢复表的结构

mysql -uroot -p'密码'  -D 库名  < 备份存放库的路径

2.4 恢复表中数据

#我们首先将hh表的数据备份到/var/lib/mysql-files/db1-hh.sql
mysql> select * from db1.hh into outfile '/var/lib/mysql-files/db1-hh.sql';

#将hh表的数据全部清除
mysql> truncate hh;

#恢复hh表的数据
mysql> load data infile '/var/lib/mysql-files/db1-hh.sql' into table hh;


#查看是否恢复
mysql> select * from hh;
+----+------+--------+-------+
| id | name | gender | hobby |
+----+------+--------+-------+
|  1 | tom  | 男     | cf    |
+----+------+--------+-------+
1 row in set (0.00 sec)

语法:mysql >  load  data  infile  '/var/lib/mysql-files/b.txt'   into  table  要恢复表数据的表名 ;

引号里面是存放备份表数据的路径,语法可以记为  load data infile 加载数据文件进来, into  table  到这个表里面来!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1062144.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

输入一个大写字母,程序根据输入字符在字母表的顺序位置n,输出一个高度为n的金字塔图形

python字母金字塔根据输入的字母输出一个字母金字塔输入一个大写字母&#xff0c;程序根据输入字符在字母表的顺序位置n,输出一个高度为n的金字塔图形&#xff0c;比如输入E时&#xff0c;此时 字母金字塔 # A # ABA # ABCBA # ABCDCBA # ABCDEDCBA 看到…

php单独使用think-rom数据库 | thinkphp手动关闭数据库连接

背景&#xff08;think-orm2.0.61&#xff09; 由于需要长时间运行一个php脚本&#xff0c;而运行过程并不是需要一直与数据库交互&#xff0c;但thinkphp主要是为web站点开发的框架&#xff0c;而站点一般都是数据获取完则进程结束&#xff0c;所以thinkphp没提供手动关闭数据…

Trie树(字典树)C++详解

字典树的定义 字典树是一个用来快速查找和存储字符串集合的数据结构。 字典树的形状 假设我们字典树里有以下5个单词&#xff1a; akio&#xff0c;akno&#xff0c;cspj&#xff0c;csps&#xff0c;trie 那么字典树长这样&#xff1a; trie 的结构非常好懂&#xff0c;我们…

软考高级之系统架构师之设计模式

概述 设计模式是一种通用的设计方法&#xff0c;实际开发中可能不止23种。为方便理解和应用&#xff0c;一般分为3类&#xff1a; 创建型&#xff0c;通过采用抽象类所定义的接口&#xff0c;封装系统中对象如何创建、组合等信息。工厂方法模式、抽象工厂模式、单例模式、建造…

堆的初步认识

在学习本节文章前要先了解&#xff1a;大顶堆与小顶堆&#xff1a; &#xff08;优先级队列_加瓦不加班的博客-CSDN博客&#xff09; 堆实现 计算机科学中&#xff0c;堆是一种基于树的数据结构&#xff0c;通常用完全二叉树实现。 什么叫完全二叉树&#xff1f; 答&#x…

8.Vue_Element

1 Ajax 1.1 Ajax介绍 1.1.1 Ajax概述 我们前端页面中的数据&#xff0c;如下图所示的表格中的学生信息&#xff0c;应该来自于后台&#xff0c;那么我们的后台和前端是互不影响的2个程序&#xff0c;那么我们前端应该如何从后台获取数据呢&#xff1f;因为是2个程序&#xf…

JavaEE-文件IO操作

构造方法 一般方法&#xff0c;有很多&#xff0c;我们以下只是列举几个经常使用的 注意在上述的操作过程中&#xff0c;无论是绝对路径下的这个文件还是相对路径下的这个文件&#xff0c;都是不存在的 Reader 使用 --> 文本文件 FileReader类所涉及到的一些方法 Fil…

Covert Communication 与选择波束(毫米波,大规模MIMO,可重构全息表面)

Covert Communication for Spatially Sparse mmWave Massive MIMO Channels 2023 TOC abstract 隐蔽通信&#xff0c;也称为低检测概率通信&#xff0c;旨在为合法用户提供可靠的通信&#xff0c;并防止任何其他用户检测到合法通信的发生。出于下一代通信系统安全链路的强烈…

C#学习系列相关之多线程(一)----常用多线程方法总结

一、多线程的用途 在介绍多线程的方法之前首先应当知道什么是多线程&#xff0c; 在一个进程内部可以执行多个任务&#xff0c;而这每一个任务我们就可以看成是一个线程。是程序使用CPU的基本单位。进程是拥有资源的基本单位&#xff0c; 线程是CPU调度的基本单位。多线程的作用…

iStoreOS搭建主路由有什么好处

iStoreOS 作为一种功能强大的软路由系统&#xff0c;搭建主路由可以带来多种好处。本文泪雪网将详细介绍 iStoreOS 搭建主路由的好处&#xff0c;包括增强网络安全性、提供更灵活的网络管理、实现高级功能和提升性能等方面。 一、增强网络安全性 iStoreOS 搭建主路由可以增强网…

计算机毕业设计 基于协调过滤算法的绿色食品推荐系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

YOLOV7改进-添加EIOU,SIOU,AlphaIOU,FocalEIOU

打开utils->general.py 找到bbox_iou&#xff08;&#xff09;&#xff0c;345行左右&#xff0c;将下面的与源码进行替换 def bbox_iou(box1, box2, x1y1x2y2True, GIoUFalse, DIoUFalse, CIoUFalse, SIoUFalse, EIoUFalse, WIoUFalse, FocalFalse, alpha1, gamma0.5, sc…

【智慧校园源码】中小学智慧班牌系统,实现校园信息化交流建设,提高班级管理效率

智慧班牌系统源码 电子班牌原生小程序源码 智慧校园云平台系统源码 智慧班牌可以通过以云平台为基础&#xff0c;结合互联网、物联网系统进行校园管理&#xff0c;实现学校数据、教学资源共享&#xff0c;推进校园信息化交流建设。而展示在班牌终端的信息可以随时更改和上传新的…

使用nginx作为API网关

使用nginx作为API网关 如果我们需要部署反向代理&#xff0c;我们可能已经听说过 nginx。如果我们还没听说过&#xff0c;让我们在这篇文章谈一谈它&#xff0c;以及我们如何使用它作为API网关。 什么是nginx? nginx是一个HTTP服务器和反向代理&#xff0c;一个邮件代理服务…

【软件测试】自动化测试selenium(二)

文章目录 三. 掌握Selenium常用的API使用1. webdriver API2. 操作测试对象3. 添加等待4. 打印信息5. 浏览器的操作6. 键盘事件7. 鼠标事件8. 定位一组元素9. 多层框架/窗口定位10. 下拉框处理11. 弹窗处理12. 上传文件13. 关闭浏览器14. 切换窗口15. 截图操作 三. 掌握Selenium…

python实现 线性卷积用Toeplitz 矩阵运算

python实现 线性卷积用Toeplitz 矩阵运算 前言 在看论文的时候&#xff0c;发现Toeplitz 矩阵和线性卷积有关系&#xff0c;于是翻了程佩青老师的数字信号处理课本&#xff0c;发现是有讲过这点的。 Toeplitz 矩阵&#xff1a;从左上到右下的斜对角线都相同&#xff0c;如下…

性能测试工具 - LoadRunner

什么是性能测试&#xff1f; 性能测试就是测试人员利用性能测试工具模拟系统在不同情况下的性能指标是否正常。 性能测试工具 - LoadRunner 接下来介绍LoadRunner的作用和使用。 LoadRunner 就是一个很常见的性能测试工具&#xff0c;它有三个部分组成&#xff1a; 这三个组…

GhostNet原理解析及pytorch实现

论文&#xff1a;https://arxiv.org/abs/1911.11907 源码&#xff1a;https://github.com/huawei-noah/ghostnet 简要论述GhostNet的核心内容。 Ghost Net 1、Introduction 在训练良好的深度神经网络的特征图中&#xff0c;丰富甚至冗余的信息通常保证了对输入数据的全面理…

MySQL:数据库的物理备份和恢复-冷备份(3)

介绍 物理备份&#xff1a; 直接复制数据文件进行的备份 优点&#xff1a;不需要其他的工具&#xff0c;直接复制就好&#xff0c;恢复直接复制备份文件即可 缺点&#xff1a;与存储引擎有关&#xff0c;跨平台能力较弱 逻辑备份&#xff1a; 从数据库中导出数据另存而进行的备…

Linux YUM源(本地/网络源)配置详解

目录 一、挂载 二、建立本地源 配置详解&#xff1a; 三、建立网络源 配置详解&#xff1a; 四、验证 一、挂载 ——将光盘挂载到 /mnt ——挂载光盘时要保证虚拟机光盘处于连接状态 命令&#xff1a;[rootlocalhost mnt]# mount /dev/sr0 /mnt # 此时还未挂载 [rootlo…