PG如何通过元命令获取表文件大小?
有三种方式,下面依次介绍。
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估算表有多少页、多少记录:
curpages = RelationGetNumberOfBlocks(rel);//真实多少页//pg_class中统计的多少页和多少记录relpages = (BlockNumber) rel->rd_rel->relpages;reltuples = (double) rel->rd_rel->reltuples;//真实页数少于10,真实记录少于0,且无子表,那么估算页数为10if (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);
最新活动更多
-
10 阿里AI需要算一笔账了
- 1 GPT-6要来了,但AI行业早不跟 OpenAI玩了
- 2 火爆的“Token经济学”,关乎你的钱包、职场和未来消费 | 人人能懂的产业报告
- 3 资本巨头纷纷抽身,为何中小投资者仍为AI狂热加码?
- 4 大厂财报中的AI图鉴:营收单列、玩杠杆、商业画饼
- 5 从百度到Meta,科技巨头的 AI 组织战,开打了
- 6 2026年3月,国内具身智能机器人企业融资汇总
- 7 华勤财报发布:收入规模破1700亿,利润增长近40%
- 8 宇树科技招股书透视:中外具身智能玩家生存竞速
- 9 大涨30%!智谱 AI 财报出炉:营收暴增132%,API 增长3倍,市值破 4000 亿
- 10 谷歌Gemma 4遭破解!实测:伪造支票、找盗版电影,有求必应


分享














发表评论
登录
手机
验证码
手机/邮箱/用户名
密码
立即登录即可访问所有OFweek服务
还不是会员?免费注册
忘记密码其他方式
请输入评论内容...
请输入评论/评论长度6~500个字
暂无评论
暂无评论