PostgreSQL的数据存储(十四)---数据存储

4.4.2        Vacuum操作对页面的影响

对于页面来讲,vacuum操作,无非是清理不再有用的元组(元组可见性),尽量让页面恢复到初始或不断插入数据时的页面的状态(目的是:元组相邻,保持尽可能多的空闲页面大小)。

4.5      索引数据的内部格式

索引的元组和数据的元组,表示方式不同(数据的是HeapTuple,索引的是IndexTuple)。

但其在页面上以元组为单位的存储方式,却是相同的。

同样,初始页面状态一样,有页头,页数据块;插入数据也从页面底部开始插入,逐渐到页头,此时,索引需要更新(ExecInsert函数调用ExecInsertIndexTuples函数);但删除数据的时候,索引是不被维护的(函数ExecDelete);更新数据,相当于删除和插入,需要维护索引。

4.6      表空间

表空间,由多个数据文件组成,而数据文件可以跨越不同磁盘存储,所以,表空间是物理存储的集合。

通常情况,表空间作用如下:

1)        决定数据库的物理存储空间如何分配;

2)        为用户的表等对象设置数据库存储的空间配额 

3)        分布数据于不同的物理存储设备之间,即分散IO以改善性能;  

4)        可以使得备份恢复以局部数据为单位,操作更为灵活

 

PG的表空间,可以在数据库级(create database的database)可以在表级(建表时指定TABLESPACE子句)和索引级指定。

数据库级的表空间,是为一个数据库指定默认存储使用的空间。如果这个库下的表不指定其他表空间,则数据存放数据库级的表空间中。

如果为表指定表空间,则表的数据,存储在表的表空间中。索引同理。

表空间中的单个文件最大为1GB,初始文件大小根据数据多少决定,所以,在运行过程中,数据文件会自动扩展到最大1GB后再分裂为多个文件,分裂后的文件名称相同,后缀以数字区别(如:12345,12345.1, 12345.2等)。

系统通过默认的表空间,可以参看“4.1.1外存文件样式”一节。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值