除了将有关数据库对象的元数据存储在数据字典中之外,MySQL 还以序列化的形式存储它。此数据称为序列化字典信息 (SDI)。 InnoDB
将 SDI 数据存储在其表空间文件中。NDBCLUSTER
将 SDI 数据存储在 NDB 字典中。其他存储引擎将 SDI 数据存储 .sdi
在为表的数据库目录中的给定表创建的文件中。SDI 数据以紧凑的JSON
格式生成。
InnoDB
除临时表空间和撤消表空间文件外 ,所有表空间文件中都存在序列化字典信息 (SDI) 。InnoDB
表空间文件中的 SDI 记录 仅描述表空间中包含的表和表空间对象。
SDI 数据由对表或 CHECK TABLE FOR UPGRADE
. 当 MySQL 服务器升级到新版本或版本时,SDI 数据不会更新。
SDI 数据的存在提供了元数据冗余。例如,如果数据字典不可用,则可以InnoDB
使用ibd2sdi工具直接从表空间文件中提取对象元数据。
对于InnoDB
,一条 SDI 记录需要一个索引页,默认大小为 16KB。但是,SDI 数据被压缩以减少存储空间。
对于InnoDB
由多个表空间组成的分区表,SDI 数据存储在第一个分区的表空间文件中。
MySQL 服务器使用在DDL操作期间访问的内部 API 来创建和维护 SDI 记录。
该IMPORT TABLE
语句MyISAM
根据.sdi
文件中包含的信息导入 表 。有关更多信息,请参阅 第 13.2.5 节,“IMPORT TABLE 语句”。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
墨天轮个人数说知识点合集
JiekeXu
387次阅读
2025-04-01 15:56:03
MySQL数据库当前和历史事务分析
听见风的声音
384次阅读
2025-04-01 08:47:17
MySQL 生产实践-Update 二级索引导致的性能问题排查
chengang
356次阅读
2025-03-28 16:28:31
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
308次阅读
2025-04-15 14:48:05
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
293次阅读
2025-04-15 23:49:58
MySQL8.0直方图功能简介
Rock Yan
284次阅读
2025-03-21 15:30:53
云和恩墨杨明翰:安全生产系列之MySQL高危操作
墨天轮编辑部
269次阅读
2025-03-27 16:45:26
openHalo问世,全球首款基于PostgreSQL兼容MySQL协议的国产开源数据库
严少安
254次阅读
2025-04-07 12:14:29
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
209次阅读
2025-04-17 17:02:24
PG vs MySQL 执行计划解读的异同点
进击的CJR
174次阅读
2025-03-21 10:50:08