前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PG获取文件大小的方式

PG获取文件大小的方式

作者头像
yzsDBA
发布2021-01-05 14:36:02
1.7K0
发布2021-01-05 14:36:02
举报

有三种方式,下面依次介绍。

1、通过元命令获取表文件大小

通过\dt+可以得到该表大小。该元命令会转换成SQL语句去执行,实际上是通过pg_table_size函数进行获取。该函数调用calulate_table_size(rel)其中rel为表的描述结构Relation。通过这个方式计算表大小包括fsm、vm文件大小,如果有toast索引,还包括toast表大小。那么具体获取文件大小的方式是什么呢?看calculate_relation_size函数:最终通过stat函数来获取,这个得到的是文件大小,而不是占用磁盘大小。同样,对于toast索引也是通过这种方式计算得到。

2、内部计算表有多少页

通过RelationGetNumberOfBlocks只计算表主文件的多少页,调用函数RelationGetNumberOfBlocksInFork进行计算。该函数对于序列、索引或者分区索引,直接通过smgrnblocks->mdnblocks获得,对于表、toast和物化视图,调用函数table_relation_size计算出文件大小然后除以一页大小得到多少页。table_relation_size调用heapam_relation_size->smgrnblocks,和上一个方法不同之处在于是否需要包括fsm、vm在内。

3、内部估算表大小

通过estimate_rel_size->table_relation_estimate_size->heapam_estimate_rel_size估算表有多少页、多少记录:

代码语言:javascript
复制
curpages = RelationGetNumberOfBlocks(rel);//真实多少页
//pg_class中统计的多少页和多少记录
relpages = (BlockNumber) rel->rd_rel->relpages;
reltuples = (double) rel->rd_rel->reltuples;
//真实页数少于10,真实记录少于0,且无子表,那么估算页数为10
if (curpages < 10 && reltuples < 0 && !rel->rd_rel->relhassubclass)
   curpages= 10;
if (curpages == 0){//当前0页,那么0个记录
   *tuples= 0;
}
if (reltuples >= 0 && relpages> 0)
   density= reltuples / (double) relpages;//统计平均每页多少记录
else{
   tuple_width = get_rel_data_width(rel,attr_widths);
   tuple_width += overhead_bytes_per_tuple;
   density = usable_bytes_per_page /tuple_width;
}
*tuples = rint(density * (double) curpages);
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-12-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 yanzongshuaiDBA 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 有三种方式,下面依次介绍。
  • 1、通过元命令获取表文件大小
  • 2、内部计算表有多少页
  • 3、内部估算表大小
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档