独立表空间结构
表空间分为 系统表空间(存放多个表的表空间)和独立表空间(每个表都对应一个自己的表空间)
一个区就是在物理位置上连续的64个页,在表中数据量大的时候,为某个索引分配空间的时候就不再按照页为单位分配了,而是按照区为单位分配,虽然可能造成一点点空间的浪费(数据不足填充满整个区),但是从性能角度看,可以消除很多的随机I/O(在进行范围查找)
叶子节点有自己独有的区,非叶子节点也有自己独有的区。存放叶子节点的区的集合就算是一个段(segment),存放非叶子节点的区的集合也算是一个段。
一个索引会生成2个段,一个叶子节点段,一个非叶子节点段
为了考虑以完整的区为单位分配给某个段对于数据量较小的表太浪费存储空间的这种情况,提出了一个碎片(fragment)区的概念,也就是在一个碎片区中,并不是所有的页都是为了存储同一个段的数据而存在的,而是碎片区中的页可以用于不同的目的,比如有些页用于段A,有些页用于段B,有些页甚至哪个段都不属于。碎片区直属于表空间,并不属于任何一个段
段是一些零散的页面以及一些完整的区的集合