手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

InnoDB表空间、段、区简述

[日期:2018-03-03] 来源:Linux社区  作者:allenwas3 [字体: ]

1. 表空间是InnoDB存储引擎逻辑结构的最高层,所有的数据都存放在表空间中。默认,InnoDB存储引擎只有一个表空间ibdata1,即所有数据都存放在这个表空间内。如果用户启用了参数innodb_file_per_table,则每张表内的数据可以单独放到一个表空间内。

如果启用了innodb_file_per_table参数,每张表的表空间内存放的只是数据、索引和插入缓冲Bitmap页,其他数据,如undo log,插入缓冲索引页,系统事务信息,二次写缓冲等还是存放在原来的共享表空间内。

2. 常见的段有数据段,索引段,回滚段等。

数据段:B+树的叶节点。

索引段:B+树的非叶节点。

回滚段:即rollback segment,管理undo log segment。

3. 区是由连续页组成的空间,区的大小固定为1M。默认,InnoDB存储引擎页的大小为16K,即一个区中有64个连续的页。

Create table test(
  Col1 int not null auto_increment,
  Col2 varchar(7000),
  Primary key(col1)
);

创建test表,将Col2字段设为varchar(7000),保证一页最多存放2条记录。通过ls命令发现表空间默认为96K。

查看mysql的数据目录:

Select @@datadir;

system ls -lh /var/lib/mysql/db_zhang/test.ibd

本文永久更新链接地址https://www.linuxidc.com/Linux/2018-03/151175.htm

linux
相关资讯       InnoDB表空间  InnoDB段  InnoDB区 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款