数据目录概述
系统表空间
独立表空间
视图在文件系统中的表示
其他的一些文件
文件系统对数据库的影响
MySQL系统数据库简介
mysql
information_schema
performance_schema
sys
MySQL数据目录
数据目录概述
对于InnoDB来说,每个索引都对应一颗B+树。该B+树的每个节点都是一个数据页,数据页之间不必要是物理连续的,因为数据页之间由双向链表来维护这些页的顺序,为了更好的管理这些页,InnoDB引入了表空间
或者是文件空间
的概念。
系统表空间
系统表空间可以对应文件系统上一个或者多个实际的文件,默认情况下,InnoDB会在数据目录下创建一个名为ibdata1、大小为12M的文件,这是一个自扩展文件。系统表空间只有一份。
独立表空间
在MySQL5.6.6以及之后的版本,InnoDB并不会默认的把各个表的数据存储到系统表空间中,而是为每一个表建立一个独立表空间,完整的文件名称为表明.ibd
。
视图在文件系统中的表示
MySQL中的视图其实是虚拟的表,也就是某个查询语句的一个别名,在存储视图的时候只需要把它的结构存储起来就行,和表一样,描述视图结构的文件只会被放到所属数据库对应的子目录下面,只会存储一个视图名.frm文件
其他的一些文件
数据目录还会包含运行程序的一些额外文件,主要包括这几种类型的文件:
服务器进程文件 服务器日志文件 默认/自动生成的SSL和RSA证书和密钥文件
文件系统对数据库的影响
MySQL的数据都是存在文件系统中的,所以就受文件系统的制约:
数据库名称和表名称不得超过文件系统所允许的最大长度 特殊字符的问题:为了避免因为数据库名和表明出现某些特殊字符而造成文件系统不支持的情况,MySQL会把数据库名和表名中所有除了数字和拉丁字母以外的字符在文件名都映射成@+编码值的形式 文件长度受文件系统最大长度限制
MySQL系统数据库简介
mysql
存储了MySQL的用户账户和权限信息,一些存储过程、事件的定义信息。一些运行过程中产生的日志信息
information_schema
保存着MySQL服务器维护的所有其他数据库的信息,比如有哪些表、哪些索引等,这些信息都是描述性信息,也被称为元数据
performance_schema
主要保存MySQL服务器运行过程中的一些状态信息,相当于MySQL的一个性能监控
sys
主要是通过视图的信息把information_schema和performance_schema结合起来
文章转载自别动我的月亮啊,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2294次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
745次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
430次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
391次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
362次阅读
2025-04-15 14:48:05
openHalo问世,全球首款基于PostgreSQL兼容MySQL协议的国产开源数据库
严少安
348次阅读
2025-04-07 12:14:29
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
244次阅读
2025-04-15 15:27:53
MySQL 8.4 新特性深度解析:功能增强、废弃项与移除项全指南
JiekeXu
192次阅读
2025-04-18 20:21:32
GreatSQL 新版发布:MySQL 牵手“鸭子”
严少安
140次阅读
2025-04-19 14:57:56
MySQL 8.0 OCP 1Z0-908 考试题解析指南
JiekeXu
119次阅读
2025-04-29 16:17:23