亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

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

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

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

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

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

正常表的Relfilenode

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

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$

在我們對一張表執行truncate,vacuum full等操作后,會重寫這個表的數據,會引發這個表relfilenode值的變更。如下測試可以看出truncate之后,t2表的relfilenode從16808變為了16811.

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系統表中查詢出的這些表的relfilenode為0。其中pg_type、pg_proc、pg_attribute、pg_class是非共享表,在內核中稱他們為Nail表。剩余的表是在pg_global表空間里的共享表。

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

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轉化為relfilenode,
通過pg_filenode_relation可以將relfilenode轉化為oid.
既然pg_class表中不存儲oid和relfilenode的對應關系,那么PostgreSQL是怎么樣保存這個映射關系的呢?

Nail表Relfilenode的存儲機制

經過研究發現,在數據目錄里存在著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的數據庫里nail表的oid和relfilenode的映射關系。
pg_filenode.map文件的結構為:

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;

結語

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

了解更多PostgreSQL技術干貨、熱點文集、行業動態、新聞資訊、精彩活動,請訪問中國PostgreSQL社區網站:www.postgresqlchina.com

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

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

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

巨人網絡通訊聲明:本文標題《解析PostgreSQL中Oid和Relfilenode的映射問題》,本文關鍵詞  解析,PostgreSQL,中,Oid,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解析PostgreSQL中Oid和Relfilenode的映射問題》相關的同類信息!
  • 本頁收集關于解析PostgreSQL中Oid和Relfilenode的映射問題的相關信息資訊供網民參考!
  • 推薦文章
    91麻豆精品国产综合久久久| 999精品影视在线观看| 精品久久久久久综合网| 亚洲天堂在线播放| 午夜激情视频在线播放| 久久精品道一区二区三区| 国产一区二区精品尤物| 天天色色网| 日韩女人做爰大片| 人人干人人插| 国产91丝袜在线播放0| 国产成人啪精品视频免费软件| 亚洲爆爽| 久久99中文字幕| 黄色短视屏| 99久久精品国产高清一区二区| 精品久久久久久免费影院| 欧美激情一区二区三区视频 | 欧美另类videosbestsex| 在线观看导航| 99热精品在线| 可以免费看污视频的网站| 黄视频网站免费看| 99久久精品国产片| 午夜家庭影院| 美女免费精品视频在线观看| 成人免费网站久久久| 中文字幕一区二区三区精彩视频| 青草国产在线观看| 精品久久久久久中文字幕一区| 九九久久99| 九九精品影院| 可以在线看黄的网站| 国产一区二区精品尤物| 国产福利免费观看| 国产视频久久久久| 国产91精品一区| 国产精品免费久久| 99久久精品国产麻豆| 可以在线看黄的网站| 日韩一级黄色大片| 久久99青青久久99久久| 色综合久久久久综合体桃花网| 精品国产亚洲人成在线| 国产91精品一区| 久久99爰这里有精品国产| 国产91丝袜高跟系列| 黄视频网站免费| 成人影院一区二区三区| 国产国语在线播放视频| 精品国产一区二区三区久久久蜜臀| 欧美激情一区二区三区视频高清| 可以免费看毛片的网站| 国产国语在线播放视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩在线观看免费| 亚洲爆爽| 国产高清在线精品一区a| 99热视热频这里只有精品| 国产麻豆精品| 久久久久久久久综合影视网| 国产一区二区精品久久91| 免费国产在线观看| 欧美a级成人淫片免费看| 精品毛片视频| 国产成a人片在线观看视频| 高清一级片| 欧美爱色| 夜夜操网| 欧美1区| 尤物视频网站在线观看| 人人干人人插| 欧美国产日韩久久久| 麻豆系列 在线视频| 午夜欧美福利| 成人av在线播放| 人人干人人插| 欧美激情伊人| 国产精品自拍在线| 国产福利免费观看| 久草免费资源| 国产欧美精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产不卡在线播放| 一本伊大人香蕉高清在线观看| 国产不卡在线观看视频| 青青久久国产成人免费网站| 九九国产| a级毛片免费观看网站| 国产网站在线| 99久久精品费精品国产一区二区| 国产激情视频在线观看| 亚洲精品永久一区| 中文字幕一区二区三区 精品| 毛片高清| 国产精品1024永久免费视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产麻豆| 亚洲精品影院久久久久久| 日韩avdvd| 精品久久久久久中文字幕2017| 欧美a级片视频| 成人免费网站视频ww| 精品久久久久久综合网| 免费毛片播放| 在线观看成人网| 午夜欧美成人香蕉剧场| 日韩专区第一页| 欧美大片aaaa一级毛片| 欧美a级v片不卡在线观看| 国产视频一区二区在线播放| 九九久久99| 久久成人综合网| 美女免费精品视频在线观看| 欧美激情中文字幕一区二区| 日本特黄特黄aaaaa大片| 亚洲精品久久玖玖玖玖| 久久99青青久久99久久| 欧美激情一区二区三区在线| 韩国毛片免费大片| 精品视频在线看 | 国产国语对白一级毛片| 亚洲精品中文字幕久久久久久| 成人高清免费| 国产原创中文字幕| 国产成人精品综合久久久| 亚洲爆爽| 国产91视频网| 久久99爰这里有精品国产| 欧美国产日韩在线| 四虎影视久久久| 国产伦精品一区二区三区在线观看 | 亚洲第一页乱| 国产麻豆精品免费密入口| 国产成人欧美一区二区三区的| 日韩在线观看免费| 四虎影视久久久| 成人高清免费| 午夜激情视频在线观看| 亚洲天堂免费| 91麻豆国产福利精品| 精品国产三级a| 日韩一级精品视频在线观看| 免费国产在线观看不卡| 91麻豆精品国产自产在线观看一区 | 日日夜夜婷婷| 国产视频网站在线观看| 韩国毛片 免费| 国产视频一区二区三区四区| 国产麻豆精品免费密入口| 欧美一级视频免费观看| 一本伊大人香蕉高清在线观看| 久久精品欧美一区二区| 99久久精品国产国产毛片| 国产一区二区福利久久| 欧美1卡一卡二卡三新区| 久久精品道一区二区三区| 可以免费看污视频的网站| 美女免费精品视频在线观看| 四虎影视久久久| 精品国产亚洲人成在线| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产片| 99久久精品国产高清一区二区| 日日夜夜婷婷| 国产a毛片| 精品视频在线看 | 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 一本高清在线| 韩国毛片 免费| 精品在线观看一区| 一级女性全黄久久生活片| 高清一级毛片一本到免费观看| 99久久精品国产免费| 欧美1卡一卡二卡三新区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 91麻豆爱豆果冻天美星空| 成人av在线播放| 国产不卡在线观看视频| 999精品影视在线观看| 精品视频在线观看免费| 国产不卡在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | a级毛片免费观看网站| 色综合久久久久综合体桃花网| 国产美女在线观看| 国产伦理精品| 韩国三级一区| 97视频免费在线观看| 日本免费乱人伦在线观看 | 精品在线观看国产| 黄色免费三级| 99久久精品国产国产毛片| 精品视频在线看 | 亚洲精品影院| 999精品影视在线观看| 成人a大片高清在线观看| 亚洲精品永久一区| 国产伦精品一区三区视频| 久久久成人网|