前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql数据目录(2)---表数据结构(二十五)

Mysql数据目录(2)---表数据结构(二十五)

作者头像
用户9919783
发布2022-07-26 12:24:47
5960
发布2022-07-26 12:24:47
举报
文章被收录于专栏:后端从入门到精通

上篇文章我们介绍了mysql的安装目录和 数据存储目录是不同的,当create database时,会在数据存储目录下新建一个同名的数据库文件,进入指定数据库文件会有db.opt文件记录数据库的特点,字符集,比较规则等。当create table时,会在指定数据库目录下,建立同名的子表目录,里面有表结构文件表名.frm和表数据文件。

Mysql数据目录(1)---数据库结构(二十四)

InnoDB存储表数据

上篇文章介绍了表结构文件.frm,这篇文章介绍表数据文件。前面说过innoDB是通过页的形式存储数据,一页大概16kb。每颗索引都是b+树,b+树的每个节点都属于数据页,数据页之间不需要物理连接起来,他们是通过文件头的双向链表来链接的。聚簇索引的叶子节点存储着用户记录的完整数据,即数据是索引,索引是数据。

那么如何管理这些页的呢?为了管理好这些页,innoDB提出表空间table space(或者文件空间file space)的概念管理他们。每个表空间里可以被划分很多很多的页,主要下面介绍两个。

系统表空间(system table space)

默认情况下,innoDB会在数据文件下,创建ibdata1文件,大小大概 12m,那是因为这个文件是自扩展性文件,当数据越来越多的时候,他会字节增加文件大小。

我们也可以在mysql服务器启动的时候,innodb_data_file_path=data1:512M;data2:512M:autoextend

加上这个配置文件,创建两个512m的文件,其中autoextend表示,当文件不够用时,创建data2。

需要注意的是,在mysql中,系统表空间只有一份,从mysql5.5.7到5.6.6之间,我们表中的数据默认存在系统表空间。

独立表空间(file-pre table space)

在mysql5.6.6版本之后,innoDB不会吧默认的表存储在系统表空间中,而是每个表都建立独立的空间,我们独立的表文件在之前表结构文件附近,表结构文件是表名.frm,表数据文件是表名.ibd。其中.frm是存储表结构行格式,字符集等,.ibd文件存储的是索引和数据的。如果我们想特意吧数据存在系统表结构里,在mysql启动时,可以配置,

innodb_file_per_table=0,表示使用系统表空间,

innodb_file_per_table=1,等于1表示使用独立表空间,

但这种是对新建立的表起作用,以前分配好的旧表 不行,设置旧表需要以下语句:

1)吧系统空间的表转移到独立表空间

ALTER TABLE 表名 TABLESPACE innodb_file_per_table;

2)吧独立表空间转移到系统表空间

ALTER TABLE 表名 TABLESPACE innodb_system;

其他类型表空间

随着mysql的发展,越来越多的表空间,比如通用表空间(general table space),undo 表空间(undo table space),临时表空间(temporary table space)等等,这里就先不一一介绍,后面遇到再说。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-08-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 后端从入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档