婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 解析PostgreSQL中Oid和Relfilenode的映射問題

解析PostgreSQL中Oid和Relfilenode的映射問題

熱門標簽:江蘇400電話辦理官方 電銷機器人能補救房產(chǎn)中介嗎 天津開發(fā)區(qū)地圖標注app 濟南外呼網(wǎng)絡電話線路 地圖標注要花多少錢 廣州電銷機器人公司招聘 400電話申請客服 移動外呼系統(tǒng)模擬題 電話機器人怎么換人工座席

作者李傳成
中國PG分會認證專家,瀚高軟件資深內(nèi)核研發(fā)工程師
https://zhuanlan.zhihu.com/p/342466054

PostgreSQL中的表會有一個RelFileNode值指定這個表在磁盤上的文件名(外部表、分區(qū)表除外)。一般情況下在pg_class表的relfilenode字段可以查出這個值,但是有一些特定表在relfilenode字段的查詢結(jié)果是0,這個博客中將會探究這些特殊表relfilenode的內(nèi)核處理。

正常表的Relfilenode

當我們創(chuàng)建一張普通表時,在pg_class系統(tǒng)表里可以查詢出其relfilenode,可以看出在表剛剛創(chuàng)建時其oid和relfilenode都是16808,在磁盤上也可以查詢到16808這個文件。事實上,這個文件存儲了我們向表t2插入的數(shù)據(jù)。

postgres=# create table t2(i int);
CREATE TABLE
postgres=# select oid,relname,relfilenode from pg_class where relname = 't2';
 oid | relname | relfilenode 
-------+---------+-------------
 16808 | t2   |    16808
(1 row)

postgres=# \q
movead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16808 
-rw-------+ 1 movead movead 0 12月 31 17:11 ../data/base/12835/16808
movead@movead-PC:/h2/pgpgpg/bin$

在我們對一張表執(zhí)行truncate,vacuum full等操作后,會重寫這個表的數(shù)據(jù),會引發(fā)這個表relfilenode值的變更。如下測試可以看出truncate之后,t2表的relfilenode從16808變?yōu)榱?6811.

postgres=# truncate t2;
TRUNCATE TABLE
postgres=# select oid,relname,relfilenode from pg_class where relname = 't2';
 oid | relname | relfilenode 
-------+---------+-------------
 16808 | t2   |    16811
(1 row)

postgres=# checkpoint;
CHECKPOINT
postgres=# \q
movead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16808
ls: 無法訪問'../data/base/12835/16808': 沒有那個文件或目錄
movead@movead-PC:/h2/pgpgpg/bin$ ll ../data/base/12835/16811
-rw-------+ 1 movead movead 0 12月 31 17:16 ../data/base/12835/16811
movead@movead-PC:/h2/pgpgpg/bin$

Nail表的Relfilenode

postgres=# select oid, relname, relfilenode,reltablespace
from pg_class
where relfilenode = 0 and relkind = 'r'
order by reltablespace;
 oid |    relname    | relfilenode | reltablespace 
------+-----------------------+-------------+---------------
 1247 | pg_type        |      0 |       0
 1255 | pg_proc        |      0 |       0
 1249 | pg_attribute     |      0 |       0
 1259 | pg_class       |      0 |       0
 3592 | pg_shseclabel     |      0 |     1664
 1262 | pg_database      |      0 |     1664
 2964 | pg_db_role_setting  |      0 |     1664
 1213 | pg_tablespace     |      0 |     1664
 1261 | pg_auth_members    |      0 |     1664
 1214 | pg_shdepend      |      0 |     1664
 2396 | pg_shdescription   |      0 |     1664
 1260 | pg_authid       |      0 |     1664
 6000 | pg_replication_origin |      0 |     1664
 6100 | pg_subscription    |      0 |     1664
(14 rows)

postgres=#

上述查詢可以看出,從pg_class系統(tǒng)表中查詢出的這些表的relfilenode為0。其中pg_type、pg_proc、pg_attribute、pg_class是非共享表,在內(nèi)核中稱他們?yōu)镹ail表。剩余的表是在pg_global表空間里的共享表。

pg_class表中relfilenode字段的意義是為了告訴程序,某一張表在磁盤上存儲的文件名。比如我們查詢t2表時,一定會先到pg_class系統(tǒng)表中獲取其relfilenode,然后到磁盤找到這個文件,然后打開并掃描。可是如果我們想查詢pg_class系統(tǒng)表在磁盤上的文件名時,應該去哪找到它的relfilenode?在PostgreSQL中提供了一組函數(shù)接口進行oid和relfilenode的轉(zhuǎn)化。

postgres=# select pg_relation_filenode(1259);
 pg_relation_filenode 
----------------------
        16475
(1 row)

postgres=# select pg_filenode_relation(0,16475);
 pg_filenode_relation 
----------------------
 pg_class
(1 row)

postgres=# select pg_filenode_relation(0,16475)::oid;
 pg_filenode_relation 
----------------------
         1259
(1 row)

postgres=#

通過pg_relation_filenode()可以將oid轉(zhuǎn)化為relfilenode,
通過pg_filenode_relation可以將relfilenode轉(zhuǎn)化為oid.
既然pg_class表中不存儲oid和relfilenode的對應關系,那么PostgreSQL是怎么樣保存這個映射關系的呢?

Nail表Relfilenode的存儲機制

經(jīng)過研究發(fā)現(xiàn),在數(shù)據(jù)目錄里存在著pg_filenode.map文件,如下所示。

movead@movead-PC:/h2/pgpgpg/data/base/12835$ ll pg_filenode.map 
-rw-------+ 1 movead movead 512 12月 31 15:10 pg_filenode.map
movead@movead-PC:/h2/pgpgpg/data/base/12835$
movead@movead-PC:/h2/pgpgpg/data/global$ ll pg_filenode.map 
-rw-------+ 1 movead movead 512 12月 31 15:10 pg_filenode.map
movead@movead-PC:/h2/pgpgpg/data/global$

在global目錄下的pg_filenode.map文件里存儲了shared表的oid和relfilenode的映射關系,12835目錄下存儲了OID為12835的數(shù)據(jù)庫里nail表的oid和relfilenode的映射關系。
pg_filenode.map文件的結(jié)構(gòu)為:

typedef struct RelMapping
{
  Oid     mapoid;     /* OID of a catalog */
  Oid     mapfilenode;  /* its filenode number */
} RelMapping;

typedef struct RelMapFile
{
  int32    magic;     /* always RELMAPPER_FILEMAGIC */
  int32    num_mappings;  /* number of valid RelMapping entries */
  RelMapping mappings[MAX_MAPPINGS];
  pg_crc32c  crc;      /* CRC of all above */
  int32    pad;      /* to make the struct size be 512 exactly */
} RelMapFile;

結(jié)語

這個博客主要闡述了在PostgreSQL中表的oid和relfilenode映射的兩種不同表現(xiàn)形式,你只要記住使用pg_relation_filenode()永遠會得到正確的結(jié)果,從pg_class系統(tǒng)表中查詢則可能會得到錯誤的結(jié)果。

了解更多PostgreSQL技術干貨、熱點文集、行業(yè)動態(tài)、新聞資訊、精彩活動,請訪問中國PostgreSQL社區(qū)網(wǎng)站:www.postgresqlchina.com

到此這篇關于PostgreSQL中Oid和Relfilenode的映射的文章就介紹到這了,更多相關PostgreSQL中Oid和Relfilenode的映射內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 解決PostgreSQL Array使用中的一些小問題
  • postgresql 中的 like 查詢優(yōu)化方案
  • PostgreSQL regexp_matches替換like模糊查詢的操作
  • postgresql 實現(xiàn)replace into功能的代碼
  • PostgreSQL 禁用全表掃描的實現(xiàn)

標簽:溫州 榆林 寶雞 濮陽 海西 昭通 杭州 辛集

巨人網(wǎng)絡通訊聲明:本文標題《解析PostgreSQL中Oid和Relfilenode的映射問題》,本文關鍵詞  解析,PostgreSQL,中,Oid,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解析PostgreSQL中Oid和Relfilenode的映射問題》相關的同類信息!
  • 本頁收集關于解析PostgreSQL中Oid和Relfilenode的映射問題的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人欧美一区二区三区1314| 91精品国产色综合久久久蜜香臀| 91蜜桃免费观看视频| 精品国产乱码91久久久久久网站| 亚洲va在线va天堂| 在线区一区二视频| 亚洲美女少妇撒尿| 成人性生交大片免费看在线播放| www国产成人| 激情综合网av| 亚洲精品在线三区| 久久精品国产精品亚洲精品| 91精品国产一区二区三区香蕉| 亚洲高清免费视频| 欧美日韩一区二区三区高清| 午夜婷婷国产麻豆精品| 91麻豆精品国产91久久久| 99热这里都是精品| 国产精品久久久久影院色老大| 大胆亚洲人体视频| 亚洲三级久久久| 在线观看国产91| 天堂一区二区在线免费观看| 制服.丝袜.亚洲.另类.中文| 免费一区二区视频| 久久久久一区二区三区四区| 成人性生交大片免费看中文| 日韩理论电影院| 欧美日韩免费一区二区三区视频 | 粉嫩久久99精品久久久久久夜| 久久精品视频免费观看| 懂色av一区二区三区蜜臀| 一区精品在线播放| 欧美日韩一区二区三区免费看| 蜜桃精品视频在线观看| 欧美国产一区视频在线观看| 色综合夜色一区| 日韩av成人高清| 国产婷婷色一区二区三区四区| av资源网一区| 午夜激情一区二区| 久久久久久久久岛国免费| 91色视频在线| 亚洲亚洲精品在线观看| 日韩欧美aaaaaa| 91香蕉国产在线观看软件| 日本强好片久久久久久aaa| 精品国产一区二区在线观看| fc2成人免费人成在线观看播放| 亚洲午夜精品网| 日韩西西人体444www| 成人免费黄色大片| 亚洲综合久久av| 国产欧美日韩亚州综合 | 国产精品美女久久久久久久网站| 91免费小视频| 久久国产免费看| 亚洲欧美日韩国产中文在线| 日韩一区二区三免费高清| 精品国产露脸精彩对白| 91免费视频网址| 国产精品 日产精品 欧美精品| 一区二区欧美视频| 日韩精品一区二区三区四区 | 欧美v国产在线一区二区三区| 91在线观看免费视频| 欧美aaaaaa午夜精品| 亚洲人成人一区二区在线观看| 欧美成人精品高清在线播放| 欧美主播一区二区三区| 处破女av一区二区| 国产中文字幕一区| 午夜久久久影院| 亚洲视频狠狠干| 久久精品水蜜桃av综合天堂| 91精品国产福利在线观看 | 99久久精品国产网站| 另类综合日韩欧美亚洲| 亚洲电影中文字幕在线观看| 国产精品欧美一级免费| 欧美精品一区视频| 777久久久精品| 欧美亚洲高清一区二区三区不卡| www.性欧美| 国产不卡高清在线观看视频| 麻豆91在线观看| 日韩电影在线观看一区| 亚洲第一久久影院| 一区二区三区免费网站| 国产精品久久久久一区| 国产日产欧美一区二区三区 | www.久久久久久久久| 国产在线乱码一区二区三区| 亚洲不卡一区二区三区| 亚洲综合成人在线视频| 亚洲人123区| 中文字幕一区二区三区不卡| 中文字幕的久久| 久久久精品黄色| 久久蜜桃一区二区| 26uuu欧美日本| 精品少妇一区二区三区在线视频| 一区二区三区精品视频在线| 中文字幕va一区二区三区| 国产精品麻豆一区二区| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 全国精品久久少妇| 亚洲国产精品久久艾草纯爱| 一区二区三区欧美| 亚洲图片欧美视频| 亚洲丰满少妇videoshd| 婷婷综合五月天| 蜜臀久久99精品久久久久久9| 蜜臀av性久久久久蜜臀aⅴ四虎| 麻豆国产91在线播放| 激情久久久久久久久久久久久久久久| 精品一区中文字幕| 国产99一区视频免费| 不卡的av在线| 91久久精品国产91性色tv| 欧美视频一二三区| 日韩欧美中文一区| 久久久99免费| 《视频一区视频二区| 伊人色综合久久天天| 偷窥少妇高潮呻吟av久久免费 | 中文字幕高清不卡| 国产精品二区一区二区aⅴ污介绍| 亚洲欧洲日韩女同| 亚洲一区二区在线免费看| 日本强好片久久久久久aaa| 国内国产精品久久| 国产91在线观看| 欧美在线一二三四区| 日韩欧美在线1卡| 欧美国产一区二区| 亚洲成人久久影院| 国产美女娇喘av呻吟久久| 97久久超碰国产精品| 91精品国产综合久久精品| 中文字幕免费不卡| 午夜精品久久久久久久久久久| 国产制服丝袜一区| 91福利精品视频| 久久免费的精品国产v∧| 亚洲免费资源在线播放| 精品在线免费视频| 色婷婷综合激情| 日韩午夜电影av| 亚洲女人****多毛耸耸8| 蜜臀久久99精品久久久久宅男| 不卡一区中文字幕| 日韩美女天天操| 悠悠色在线精品| 国产成人综合精品三级| 欧美放荡的少妇| 国产原创一区二区| 欧美无砖专区一中文字| 久久久久久久网| 亚洲www啪成人一区二区麻豆| 国产高清一区日本| 欧美一区二区视频在线观看| 国产精品九色蝌蚪自拍| 久久精品99国产精品日本| 色婷婷久久一区二区三区麻豆| 精品999在线播放| 天天综合天天综合色| 91丨九色丨蝌蚪丨老版| 国产午夜精品一区二区三区四区 | 国产欧美一二三区| 日韩国产欧美在线播放| 成人爽a毛片一区二区免费| 欧美一区二区日韩| 亚洲电影在线播放| 色一情一伦一子一伦一区| 国产丝袜在线精品| 国产一区二区三区在线观看免费| 91精品国产综合久久福利软件 | 亚洲免费av高清| 粉嫩绯色av一区二区在线观看| 日韩欧美国产系列| 三级成人在线视频| 在线观看亚洲a| 一区二区三区自拍| 成人午夜视频福利| 久久久久国产精品免费免费搜索| 久久99国产精品久久| 欧美日韩1区2区| 性久久久久久久久| 欧美日免费三级在线| 国产精品福利一区| av成人老司机| 亚洲女厕所小便bbb| 99v久久综合狠狠综合久久| 国产精品视频一二三区| 狠狠色伊人亚洲综合成人| 精品少妇一区二区三区免费观看| 蜜臀av一级做a爰片久久| 欧美一区日韩一区| 久久99国产精品麻豆|