PG如何通過(guò)元命令獲取表文件大?
有三種方式,下面依次介紹。
1、通過(guò)元命令獲取表文件大小
通過(guò)dt+可以得到該表大小。該元命令會(huì)轉(zhuǎn)換成SQL語(yǔ)句去執(zhí)行,實(shí)際上是通過(guò)pg_table_size函數(shù)進(jìn)行獲取。該函數(shù)調(diào)用calulate_table_size(rel)其中rel為表的描述結(jié)構(gòu)Relation。通過(guò)這個(gè)方式計(jì)算表大小包括fsm、vm文件大小,如果有toast索引,還包括toast表大小。那么具體獲取文件大小的方式是什么呢?看calculate_relation_size函數(shù):最終通過(guò)stat函數(shù)來(lái)獲取,這個(gè)得到的是文件大小,而不是占用磁盤(pán)大小。同樣,對(duì)于toast索引也是通過(guò)這種方式計(jì)算得到。
2、內(nèi)部計(jì)算表有多少頁(yè)
通過(guò)RelationGetNumberOfBlocks只計(jì)算表主文件的多少頁(yè),調(diào)用函數(shù)RelationGetNumberOfBlocksInFork進(jìn)行計(jì)算。該函數(shù)對(duì)于序列、索引或者分區(qū)索引,直接通過(guò)smgrnblocks->mdnblocks獲得,對(duì)于表、toast和物化視圖,調(diào)用函數(shù)table_relation_size計(jì)算出文件大小然后除以一頁(yè)大小得到多少頁(yè)。table_relation_size調(diào)用heapam_relation_size->smgrnblocks,和上一個(gè)方法不同之處在于是否需要包括fsm、vm在內(nèi)。
3、內(nèi)部估算表大小
通過(guò)estimate_rel_size->table_relation_estimate_size->heapam_estimate_rel_size估算表有多少頁(yè)、多少記錄:
curpages = RelationGetNumberOfBlocks(rel);//真實(shí)多少頁(yè)//pg_class中統(tǒng)計(jì)的多少頁(yè)和多少記錄relpages = (BlockNumber) rel->rd_rel->relpages;reltuples = (double) rel->rd_rel->reltuples;//真實(shí)頁(yè)數(shù)少于10,真實(shí)記錄少于0,且無(wú)子表,那么估算頁(yè)數(shù)為10if (curpages < 10 && reltuples < 0 && !rel->rd_rel->relhassubclass) curpages= 10;if (curpages == 0){//當(dāng)前0頁(yè),那么0個(gè)記錄 *tuples= 0;}if (reltuples >= 0 && relpages> 0) density= reltuples / (double) relpages;//統(tǒng)計(jì)平均每頁(yè)多少記錄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);
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
即日-10.29立即報(bào)名>> 2024德州儀器嵌入式技術(shù)創(chuàng)新發(fā)展研討會(huì)
-
10月31日立即下載>> 【限時(shí)免費(fèi)下載】TE暖通空調(diào)系統(tǒng)高效可靠的組件解決方案
-
即日-11.13立即報(bào)名>>> 【在線會(huì)議】多物理場(chǎng)仿真助跑新能源汽車(chē)
-
11月14日立即報(bào)名>> 2024工程師系列—工業(yè)電子技術(shù)在線會(huì)議
-
12月19日立即報(bào)名>> 【線下會(huì)議】OFweek 2024(第九屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
-
即日-12.26火熱報(bào)名中>> OFweek2024中國(guó)智造CIO在線峰會(huì)
推薦專題
- 1 Intel宣布40年來(lái)最重大轉(zhuǎn)型:年底前裁員15000人、拋掉2/3房產(chǎn)
- 2 因美封殺TikTok,字節(jié)股價(jià)骨折!估值僅Meta1/5
- 3 宏山激光重磅發(fā)布行業(yè)解決方案,助力智能制造產(chǎn)業(yè)新飛躍
- 4 國(guó)產(chǎn)AI芯片公司破產(chǎn)!白菜價(jià)拍賣(mài)
- 5 具身智能火了,但規(guī)模落地還需時(shí)間
- 6 國(guó)產(chǎn)英偉達(dá)們,抓緊沖刺A股
- 7 三次錯(cuò)失風(fēng)口!OpenAI前員工殺回AI編程賽道,老東家捧金相助
- 8 英特爾賦能智慧醫(yī)療,共創(chuàng)數(shù)字化未來(lái)
- 9 英偉達(dá)的麻煩在后頭?
- 10 將“網(wǎng)紅”變成“商品”,AI“爆改”實(shí)力拉滿
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷(xiāo)售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷(xiāo)售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門(mén)市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市