【赵渝强老师】MySQL InnoDB的表空间

InnoDB存储引擎目前是MySQL默认的存储引擎,它主要由三部分组成,分别是:存储结构、内存结构和线程结构。InnoDB的存储结构又可以分为逻辑存储结构和物理存储结构。InnoDB存储引擎的逻辑存储结构和Oracle大致相同,所有数据都被逻辑地存放在一个空间中,我们称之为表空间(tablespace)。表空间又由段(segment)、区(extent)、页(page)组成。

视频讲解如下:

MySQL InnoDB的表空间
【赵渝强老师】MySQL InnoDB的表空间

InnoDB存储引擎的逻辑存储结构大致如下图所示。

下面重点介绍一下MySQL InnoDB逻辑存储结构中的表空间。

表空间可以看做是InnoDB存储引擎逻辑结构的最高层,所有的数据都是存放在表空间中。默认情况下InnoDB存储引擎有一个共享表空间ibdata1,用于存放撤销(Undo)信息、系统事务信息、二次写缓冲(double write buffer)数据等。下面展示了该表空间所对应的物理文件。

powershell 复制代码
[root@mysql11 data]# cd /usr/local/mysql/data/
[root@mysql11 data]# ll ibdata1 
-rw-r-----. 1 mysql mysql 12582912 Feb 19 21:11 ibdata1

如果我们启用了参数"innodb_file_per_table",则每张表内的数据可以单独放到一个表空间内。该参数也是默认启用的。

sql 复制代码
mysql> show variables like 'innodb_file_per_table';

# 输出的信息如下:
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| innodb_file_per_table | ON    |
+-----------------------+-------+

提示:对于启用了innodb_file_per_table的参数选项,需要注意的是,每张表的表空间内存放的只是数据、索引和插入缓冲的数据,如撤销(Undo)信息、系统事务信息、二次写缓冲(double write buffer)数据等还是存放在原来的共享表空间内。这也就说明了另一个问题:即使在启用了参数innodb_file_per_table之后,共享表空间还是会不断地增加其大小。

相关推荐
阿里云大数据AI技术4 分钟前
DataWorks千万级任务调度与全链路集成开发治理赋能智能驾驶技术突破
大数据·数据库·数据挖掘
Full Stack Developme12 分钟前
PostgreSQL dblink 与 Spring Boot @Transactional 的事务整合
数据库·spring boot·postgresql
JustNow_Man22 分钟前
【LLM】 BaseModel的作用
数据库·人工智能·python·uv
二闹29 分钟前
什么?你的 SQL 索引可能白加了!?
后端·mysql·性能优化
阿萨德528号1 小时前
5、生产Redis高并发分布式锁实战
数据库·redis·分布式·缓存
不修×蝙蝠1 小时前
MVCC:数据库事务隔离的 “时空魔法”
数据库·mvcc·多版本并发控制
rit84324992 小时前
Web学习:SQL注入之联合查询注入
前端·sql·学习
极限实验室2 小时前
Easysearch 集成阿里云与 Ollama Embedding API,构建端到端的语义搜索系统
数据库·openai
热心不起来的市民小周2 小时前
基于 Flask 和 MySQL 的期货数据分析系统
python·mysql·flask
我科绝伦(Huanhuan Zhou)2 小时前
达梦数据库备份与还原终极指南:从基础到增量策略实战
数据库·oracle