mysql8通过data文件恢复数据

2024-08-24 11:36
文章标签 数据 恢复 mysql8 data

本文主要是介绍mysql8通过data文件恢复数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

云服务器中毒,导致mysql停止。只有data文件

备份mysql数据库文件

1、执行打包命令把data文件下载至本地。
zip -r dest.zip /opt/data/mysql
2、在本地虚拟机搭建相同版本的mysql数据库。

下载python脚本转换.ibd文件为sql文件

1、python转换地址https://github.com/ddcw/ibd2sql.git
2、下载python3
3、测试
python3 /opt/ibd2sql/main.py /opt/sfms@002defms/sys_user.ibd –sql > /opt/sys_usr_s.sql
“/opt/ibd2sql/main.py”为python脚本目录。
“/opt/sfms@002defms/sys_user.ibd”为备份的.ibd文件。
“sql” 为生成insert语句。
“ddl”为生成createtable语句。
“/opt/sys_usr_s.sql”为生成sql语句的目录
生成完后查看文件内容是否正确

编写shell脚本批量执行python命令

我的表有一百多张,不可能每张表都执行python 脚本的ddl和sql命令。
所以我在centos虚拟机上编写shell脚本批量执行。
前提是在centos虚拟机上安装python3及上传ibd2sql代码河相关.ibd文件
脚本如下

#!/bin/bash
#.ibd文件位置
dir="/opt/sfms@002defms"
tstrc="_c.sql"
tstrs="_s.sql"
path="/opt/bak/"
# 遍历当前目录下的所有文件
for file in $dir/*; do# 检查是否是文件if [ -f "$file" ]; thenfilePath="$file"fileName=$(echo $filePath | rev | cut -d "/" -f 1 | rev)fileNames=$(echo $fileName | rev |cut -d"." -f 2 | rev)echo "$path"$fileNames"$tstrc"python3 /opt/ibd2sql/main.py "$file"  --ddl > "$path"$fileNames"$tstrc"python3 /opt/ibd2sql/main.py "$file"  --sql > "$path"$fileNames"$tstrs"fi
done

注意给文件赋权限chomd +x file.sh
执行file.sh

编写批量执行sql文件python代码并执

生成的*_c.sql为建表语句。
生成的*_s.sql为insert语句。
如果在navicat执行sql文件会执行很多遍,所以我就写了一个python脚本批量执行多个sql文件。
代码如下:

import mysql.connector
import os # 连接到MySQL数据库
config = {'user': 'xx','password': 'wxx*','host': 'xxx','database': 'xx'
}
cnx = mysql.connector.connect(**config)
# 创建一个游标对象
cursor = cnx.cursor()# 获取文件夹路径
folder_path = '/usr/local'
# 存储所有文件内容的列表
file_contents = []# 遍历文件夹中的每个文件
for root, dirs, files in os.walk(folder_path):for file_name in files:file_path = os.path.join(root, file_name)# 打开文件并读取内容with open(file_path, 'r',encoding='utf-8') as file:content = file.read()file_contents.append(content)# 打印所有文件内容
for content in file_contents:print(content)cursor.execute(content)# 提交并关闭连接
cnx.commit()
cursor.close()
cnx.close()

在windows电脑就可以

结束

执行完sql后,新建备份,重装mysql,还原备份

这篇关于mysql8通过data文件恢复数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102366

相关文章

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA