当前位置: 首页 > article >正文

【MySQL】MySQL如何存储元数据?

目录

1.数据字典的作用

2. MySQL 8.0 之前的数据字典

3. MySQL 8.0 及之后的数据字典

4.MySQL 8 中的事务数据字典的特征

5.数据字典的序列化

6. .sdi文件的作用:

7..sdi的存储方式


在 MySQL 中,元数据(Metadata) 是描述数据库对象(如表、列、索引、约束等)的结构信息。简单来说,元数据就是描述数据库里有哪些表、表里有哪些列、列是什么类型、谁有权限访问等信息。而数据字典是存储元数据的仓库。

1.数据字典的作用

数据字典存储了数据库的元数据,包括:

  • 数据库对象信息:如表、视图、索引、存储过程、触发器等。
  • 结构信息:如表的结构、列的数据类型、索引的类型等。
  • 约束信息:如主键、外键、唯一约束等。
  • 权限信息:用户和权限的元数据。

通过数据字典,MySQL 可以高效地管理和查询数据库对象的元数据。

2. MySQL 8.0 之前的数据字典

在 MySQL 8.0 之前,数据字典的元数据存储方式包括:

  1. 文件存储:元数据存储在 .frm 文件(表结构文件)、.par 文件(分区表文件)等中。
  2. 系统表:部分元数据存储在 information_schema  系统数据库(虚拟数据库,存储了 MySQL 服务器中所有数据库的元数据,只读)和 mysql 系统数据库中(仅存储 MySQL 核心元数据)。
  3. 在 MySQL 8.0 之前,InnoDB 系统表主要用于存储 InnoDB 存储引擎的内部信息,不用于存储 MySQL 的全局数据字典。

缺点:

  • 非事务性:元数据的更新不是事务性的,可能导致不一致。
  • 性能问题:频繁的文件操作影响性能。
  • 复杂性:元数据分散存储,管理复杂。

3. MySQL 8.0 及之后的数据字典

从 MySQL 8.0 开始,数据字典的实现发生了重大改进:

  • 基于 InnoDB:元数据存储在 mysql 系统数据库中的、使用 InnoDB 存储引擎的表中,而不再存储在 ibdata1 文件里,支持事务性操作。

  • 集中存储:所有元数据集中存储在 mysql 系统数据库下的数据字典表中。

  • 事务性:元数据的更新支持事务,确保一致性。

  • 性能提升:不再依赖 .frm 文件等外部文件存储元数据,减少了文件操作,提高了元数据访问性能。

4.MySQL 8 中的事务数据字典的特征

(1) 是所有 MySQL 服务器子系统的单一元数据存储库

统一存储

  • 在 MySQL 8.0 之前,元数据分散存储在不同的地方(如 .frm 文件、mysql 系统数据库等)。
  • 在 MySQL 8.0 中,所有元数据集中存储在 数据字典表 中,这些表位于 InnoDB 数据字典表空间(mysql.ibd)。

跨存储引擎:虽然不同的存储引擎(如 InnoDB、MyISAM)有自己的用户表,但它们的所有元数据都存储在相同的数据字典表中,这种统一存储简化了元数据的管理和访问。

(2)基于标准 SQL 定义

标准化:数据字典表基于标准 SQL 定义,使用标准的表结构和查询接口。这使得数据字典更易于扩展和维护。

公共数据字典:所有存储引擎共享同一个数据字典,避免了元数据的冗余和不一致。

自动升级:在 MySQL 8.0 中,安装程序会自动处理数据字典的升级,确保从旧版本迁移时的兼容性。

(3)使用事务存储引擎 InnoDB

事务性:数据字典表使用 InnoDB 存储引擎,支持事务性操作(ACID 特性)。这意味着元数据的更新是原子性的,要么全部成功,要么全部失败。

原子 DDL:DDL(数据定义语言)操作(如创建表、修改表结构)现在是原子性的。例如,如果在创建表的过程中发生错误,MySQL 会自动回滚,确保数据库状态一致。

损毁安全:由于数据字典存储在 InnoDB 表空间中,即使发生崩溃或断电,InnoDB 的崩溃恢复机制也能确保元数据的一致性。

(4)改进的 INFORMATION_SCHEMA

性能优化:在 MySQL 8.0 中,INFORMATION_SCHEMA 的实现基于数据字典表,使用了标准的优化技术(如索引、缓存),这使得查询 INFORMATION_SCHEMA 的性能显著提升。

更易于维护:由于 INFORMATION_SCHEMA 直接访问数据字典表,不再需要复杂的文件解析和内存管理,这使得 INFORMATION_SCHEMA 的实现更简洁、更易于维护。

5.数据字典的序列化

在 MySQL 5.6 及之前,InnoDB 存储引擎将所有的数据字典信息存储在共享表空间(即 ibdata1文件)中。这种存储方式存在一些问题:

  • 性能问题:由于数据字典的信息存储在共享表空间中,访问这些元数据时可能导致磁盘 I/O 瓶颈。
  • 恢复效率低:在恢复数据库时,重新加载共享表空间中的数据字典信息可能导致较慢的恢复速度。
  • 无法优化查询:由于数据字典在同一文件中,查询这些信息时的性能可能不是最优的。

因此,从 MySQL 5.7 开始,InnoDB 引入了 序列化字典机制,使得数据字典信息能够更高效地存储和访问。

MySQL 5.7 及以上版本中,InnoDB 使用 .sdi 文件(Serialized Dictionary Information)来专门存储序列化的数据字典信息,采用序列化格式存储。每个数据库会有一个对应的 .sdi 文件,用于存储该数据库的元数据,它包含了关于数据库、表、列、索引等的所有元数据,.sdi 文件中的数据是压缩的、序列化的元数据,MySQL 会在数据库启动时将其反序列化,以便快速访问。

序列化格式:这些元数据被序列化为一种压缩格式,InnoDB 可以在需要时快速反序列化并使用这些信息。这种方式比之前将数据字典存储在共享表空间中更加高效,尤其在高并发访问时能减少锁争用。

序列化:当数据字典信息被更新时(例如创建表、修改列、添加索引等),SDI 文件是将JSON 格式的元数据序列化为二进制数据,存储在 .sdi 文件中。序列化过程确保了元数据存储的高效性,并且节省了空间。

反序列化:在查询或操作数据库对象时,MySQL 会将 .sdi 文件中的序列化数据反序列化为可用的元数据格式。反序列化操作是在需要访问元数据时进行的,通常是高效且快速的。

6. .sdi文件的作用

每次元数据发生更改时(如创建、修改或删除表),MySQL 会自动生成它的副本 .sdi 文件。元数据以 JSON 格式序列化。

  • 元数据备份:在元数据更改时,保存当前状态的副本,便于备份、恢复或迁移
  • 数据一致性:确保元数据与数据文件的一致性,避免损坏或丢失。
  • 跨存储引擎支持:为不同存储引擎(如 InnoDB 和 MyISAM)提供统一的元数据管理机制。

7. .sdi的存储方式

MySQL 根据存储引擎的不同,将 .sdi 存储在不同的位置:

(1)InnoDB 存储引擎

  • 存储位置:存储在 InnoDB 用户表空间 中,与表的数据一起存储。
  • 文件格式被嵌入到表空间文件(.ibd 文件)中,作为表的一部分。
  • 优点:元数据与数据存储在一起,便于管理和恢复。

(2)MyISAM 存储引擎

  • 存储位置:存储在数据库目录中,作为独立的文件。
  • 文件格式:以 .sdi 文件的形式存储,文件名与表名对应。
  • 优点:独立文件便于查看和备份。

Q:那这里就有一个疑问,.sdi文件是如何为不同存储引擎(如 InnoDB 和 MyISAM)提供统一的元数据管理机制?

A:主要通过以下三种方式:

1.统一的元数据格式:无论使用 InnoDB 还是 MyISAM,SDI 的 JSON 结构是统一的,使用 JSON 格式存储元数据。

2.MySQL 提供了一个统一的数据字典 API,用于访问和管理 SDI 数据。无论底层存储引擎是 InnoDB 还是 MyISAM,上层应用(如 MySQL 服务器)都通过相同的接口读取和写入元数据。

3.统一的元数据恢复机制:在数据库崩溃或元数据损坏时,无论是 InnoDB 还是 MyISAM,,MySQL 可以通过 SDI 恢复元数据。当需要将表从一个存储引擎迁移到另一个存储引擎时,SDI 提供了一种统一的元数据表示形式。例如,可以将 MyISAM 表的 .sdi 文件解析后,直接应用到 InnoDB 表。

总之,SDI 通过统一的 JSON 格式和数据字典 API,为不同存储引擎(如 InnoDB 和 MyISAM)提供了一种一致的元数据管理机制。尽管不同存储引擎在物理存储方式上有所差异,但 SDI 确保了元数据的统一性、可移植性和可恢复性,从而简化了 MySQL 的元数据管理。

相关文章:

【MySQL】MySQL如何存储元数据?

目录 1.数据字典的作用 2. MySQL 8.0 之前的数据字典 3. MySQL 8.0 及之后的数据字典 4.MySQL 8 中的事务数据字典的特征 5.数据字典的序列化 6. .sdi文件的作用: 7..sdi的存储方式 在 MySQL 中,元数据(Metadata) 是描述数…...

《基于自适应正负样本对比学习的特征提取框架》-核心公式提炼简洁版 2022年neural networks

论文源地址 以下是从文档中提取的关于“基于对比学习的特征提取框架(CL-FEFA)”中正负样本对比学习实现的技术细节,包括详细的数学公式、特征提取过程以及特征表示方式的说明。 1. 正负样本的定义与构造 在CL-FEFA框架中,正负样…...

8.4《同一直线上二力的合成》

教会什么:合力与分力、同一直线上二力的合成 培养什么:实验抓共同点为突破口 课标: (二)运动和相互作用 2.2 机械运动和力 2.2.4 能用示意图描述力。会测量力的大小。了解同一直线上的二力合成。 零、导入 提问: 在前面我们探究了物体处于匀速直线运动/静止状态时,即处于…...

用ASCII字符转化图片

代码 from PIL import Image# 定义 ASCII 字符集,从最暗到最亮 ASCII_CHARS "%#*-:. "def resize_image(image, new_width100):width, height image.sizeratio height / widthnew_height int(new_width * ratio)resized_image image.resize((new_wi…...

zookeepernacoskafka之间的联系

一、ZooKeeper与Kafka的协同工作原理 1. 核心关系:Kafka对ZooKeeper的依赖 在Kafka 2.8版本之前,ZooKeeper是Kafka集群的“大脑”,负责管理集群元数据、协调节点状态和故障恢复。两者的协同主要通过以下关键机制实现: Broker注册…...

力扣 797. 所有可能的路径 解析JS、Java、python、Go、c++

深度优先搜索解所有可能的路径问题 题目描述 力扣链接 给你一个有 n 个节点的 有向无环图(DAG),请你找出所有从节点 0 到节点 n-1 的路径并输出(不要求按特定顺序) graph[i] 是一个从节点 i 可以访问的所有节点的列…...

蓝桥与力扣刷题(蓝桥 组队)

题目:作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员,组成球队的首发阵容。 每位球员担任 1号位至 5号位时的评分如下表所示。请你计算首发阵容 1 号位至 5 号位的评分之和最大可能是多少? 本题为填空题&…...

python函数的多种参数使用形式

目录 1. 位置参数(Positional Arguments) 2. 关键字参数(Keyword Arguments) 3. 默认参数(Default Arguments) 4. 可变参数(Variable Positional Arguments) 5. 关键字可变参数&…...

天梯赛 PTAL2-009 抢红包

很简单的一道模拟题&#xff0c;使用map统计每个用户的钱数和红包数&#xff0c;最后在使用结构体存储&#xff0c;重载小于号&#xff0c;sort排序即可。 #include <bits/stdc.h> using namespace std; #define endl \n #define int long long typedef long long ll; c…...

【京东API开发指南】三步获取商品详情页实时数据:SKU、价格、销量全解析

以下是使用京东 API 获取商品详情页实时数据&#xff08;SKU、价格、销量&#xff09;的一般步骤&#xff1a; 注册与认证 注册开发者账号&#xff1a;访问京东开放平台官网&#xff0c;完成企业实名认证&#xff08;仅支持企业开发者&#xff09;。这是使用京东 API 的前提&am…...

深入探讨TK矩阵系统:创新的TikTok运营工具

TK矩阵的应用场景 TK矩阵系统适用于多个场景&#xff0c;尤其是在以下几个方面有显著优势&#xff1a; 批量账号管理与内容发布&#xff1a;对于需要管理多个TikTok账号的内容创作者或营销人员&#xff0c;TK矩阵提供了高效的账号管理工具&#xff0c;支持批量发布视频、评论、…...

AI Agent系列(六) -基于ReAct架构搭建LLM Agent(Deepseek)

AI Agent系列【六】 一、 ReAct1.1 ReAct 的处理过程&#xff1a;1.1 代码结构 二、 Python代码实现2.1 通过Zero-shot 实现python代码实例Python代码示例1&#xff1a;python代码实现示例2 一、 ReAct ReAct 是 Reseaning 和 Action 两个词的前缀合成&#xff0c;代表着先推…...

零基础上手Python数据分析 (6):Python 异常处理,告别程序崩溃的烦恼!

回顾一下,前几篇博客我们学习了 Python 的基本语法、数据结构和文件操作。 现在,我们已经掌握了 Python 编程的基础知识,可以开始编写更复杂的数据分析代码了。 但是,在实际的数据分析工作中,程序并非总能一帆风顺地运行,总会遇到各种 意外情况,例如: 文件找不到: 程序…...

AnyTouch:跨多个视觉触觉传感器学习统一的静态动态表征

25年3月来自人大、武汉科技大学和北邮的论文“AnyTouch: Learning Unified Static-dynamic Representation Across Multiple Visuo-tactile Sensors”。 视觉触觉传感器旨在模拟人类的触觉感知&#xff0c;使机器人能够精确地理解和操纵物体。随着时间的推移&#xff0c;许多精…...

关于stm32mp157

目录 设备树&#xff1a; 内核移植&#xff1a; 编写一个驱动的过程&#xff1a; 编写i2c传感器驱动的过程&#xff1a; 从arm11后&#xff0c;命名改为cortex&#xff0c; 1.cortex A&#xff1a;高端应用型领域 2.cortex R&#xff1a;实时性要求 3.cortex M&#xff1a;…...

关于单项梯度冻结小记

单项权重冻结&#xff08;Partial Weight Freezing&#xff09;详解 单项权重冻结&#xff08;Partial Weight Freezing&#xff09; 是深度学习模型训练中的一种技巧&#xff0c;指的是在训练过程中&#xff0c;只冻结&#xff08;固定&#xff09;部分网络权重&#xff0c;而…...

Ubuntu20.04安装Nvidia显卡驱动

Ubuntu20.04安装Nvidia显卡驱动 安装环境为Dell R540服务器 官网下载Nvidia显卡驱动 https://www.nvidia.cn/geforce/drivers/ 安装显卡驱动 chmod x NVIDIA-Linux-x86_64-470.63.01.run sudo ./NVIDIA-Linux-x86_64-470.63.01.run 遇到nouveau报错 lsmod查看nouveau驱动…...

YOLOv11 目标检测

本文章不再赘述anaconda的下载以及虚拟环境的配置&#xff0c;博主使用的python版本为3.8 1.获取YOLOv11的源工程文件 链接&#xff1a;GitHub - ultralytics/ultralytics: Ultralytics YOLO11 &#x1f680; 直接下载解压 2.需要自己准备的文件 文件结构如下&#xff1a;红…...

VSCode C/C++ 环境搭建指南

一、前言 Visual Studio Code&#xff08;简称 VSCode&#xff09;是一款轻量级且功能强大的跨平台代码编辑器&#xff0c;凭借丰富的插件生态和高度的可定制性&#xff0c;深受开发者喜爱。对于 C/C 开发者而言&#xff0c;在 VSCode 中搭建开发环境&#xff0c;能够获得灵活…...

Python-docx库详解:轻松实现Word文档自动化生成与图片尺寸控制

Python-docx库详解&#xff1a;轻松实现Word文档自动化生成与图片尺寸控制 在现代办公自动化的浪潮中&#xff0c;文档处理是一项不可或缺的任务。Python作为一种强大的编程语言&#xff0c;提供了丰富的库来简化这些任务。其中&#xff0c;python-docx库是处理Word文档的有力…...

Python大疆导出csv文件转化大地2000的dxf文件

大疆导出三维模型里面有个models\pc\0\terra_grid\csv\terra_grid.csv文件&#xff0c;里面记录所有点的坐标和高程&#xff0c;但坐标是经纬度坐标&#xff0c;需要转化为大地2000坐标。 我参照了&#xff1a;经纬度坐标转换为CGCS2000大地坐标系对应XY值&#xff08;PYTHON实…...

Python 中下划线 “_” 的多面性:从变量到约定

# Python中下划线“_”的多面性&#xff1a;从变量到约定 在Python的语法体系里&#xff0c;下划线“_”看似毫不起眼&#xff0c;实则扮演着极为重要且多样化的角色。它不仅能作为普通变量参与编程&#xff0c;更在多个特殊场景下有着独特的用途与约定。深入理解下划线的各种…...

Vue3项目开发:状态管理实践指南

# Vue3项目开发&#xff1a;状态管理实践指南 一、引言 背景介绍 在Vue项目中&#xff0c;状态管理是一个非常重要的话题。合理的状态管理能够帮助我们更好地组织和管理数据&#xff0c;提升项目的可维护性和可扩展性。本文将深入探讨Vue3项目中状态管理的最佳实践&#xff0c;…...

JVM-JAVA编译到执行全过程

源码文件&#xff08;.java&#xff09;到代码执行的全过程&#xff1a; 该过程主要分为四个阶段&#xff0c;“编译-》加载-》解释-》执行”。 在编译阶段需要将源码文件&#xff08;.java&#xff09;通过语法分析、语义分析、注解处理后得到class文件&#xff1b; 在加载…...

数据结构-------栈

顺序栈&#xff1a; 一、数据结构定义 数据元素 DATATYPE typedef struct person {char name[32];char sex;int age;int score; } DATATYPE;顺序栈结构 SeqStack typedef struct list {DATATYPE *head; // 栈空间首地址int tlen; // 栈总容量&#xff08;total leng…...

机器学习概要

文章目录 一、什么是机器学习 二、机器学习的种类 1. 有监督学习 2. 无监督学习 3.强化学习 三、机器学习的应用 四、机器学习的步骤 1. 数据的重要性 2. 数据和学习的种类 3. 可视化 一、什么是机器学习 机器学习指的是计算机根据给定的问题、课题或环境进行学习&a…...

python:music21 与 AI 结合应用探讨

Python 的 music21 库与人工智能&#xff08;AI&#xff09;技术结合应用具有广泛的可能性&#xff0c;尤其是在音乐生成、分析和风格模拟等领域。以下是具体的结合方向与示例&#xff1a; 1. 音乐生成与 AI AI 模型驱动音乐生成&#xff1a; 使用深度学习模型&#xff08;如 …...

【LangChain入门 2 Model组件】开始!LLM Models简单对话

文章目录 一、使用langchain_ollama二、采用DeepSeek的API三、Model 介绍3.1 OllamaLLM 预训练模型3.2 ChatOllama 聊天预训练模型3.3 OllamaEmbeddings 实现一个helloworld&#xff0c;跑通一个简单的对话。 后面章节会正式介绍LangChain的各个功能。 后台llm的端口可以任意选…...

7种寻址方式

1. 立即寻址 立即寻址也叫立即数寻址&#xff0c;操作数本身就在指令中给出&#xff0c;只要取出指令也就取到了操作数&#xff0c;这个操作数被称为立即数。立即数要求以 “#” 为前缀。 #0x1100&#xff1a;表示十六进制数#0b1100&#xff1a;表示二进制数#0d1100&#xff…...

C语言中,#define和typedef 定义int* 一个容易混淆的点

前言 首先来看一个代码&#xff1a; #include <stdio.h> #include <string.h>#define int_ptr int *int main() {int c 100;int_ptr a , b; // 等效于int * a,b; 那么b就是int类型&#xff0c;不是int*类型a &c;b &c; //报错return 0; } 原意&#x…...