对PostgreSQL中 pg_各表的RelationId的认识
读取普通的table或者系统表,都会调用heap_open函数:
/* ----------------
* heap_open - open a heap relation by relation OID
*
* This is essentially relation_open plus check that the relation
* is not an index nor a composite type. (The caller should also
* check that it's not a view or foreign table before assuming it has
* storage.)
* ----------------
*/
Relation
heap_open(Oid relationId, LOCKMODE lockmode)
{
//fprintf(stderr,"++++++++++++++++++++ In heap_open start by process %d....relationId is:%d\n",
getpid(),relationId);
Relation r; r = relation_open(relationId, lockmode); if (r->rd_rel->relkind == RELKIND_INDEX)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is an index",
RelationGetRelationName(r))));
else if (r->rd_rel->relkind == RELKIND_COMPOSITE_TYPE)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is a composite type",
RelationGetRelationName(r)))); //fprintf(stderr,"++++++++++++++++++++ In heap_open end by process %d\n\n",getpid()); return r;
}
对于普通表而言,RelationId就是在base目录下的某个子目录里面的文件名。
但是对于系统表而言,则不同。
比如 pg_tablespace 的RelationId为 1213(这已经写死在PostgreSQL源代码中),
但是其对应的文件的名称为 12587(对应global/12587文件)。
经过一番测试,发现其对应关系如下:
pg_default_acl | 826 |
pg_pltemplate | 1136 |
pg_tablespace | 1213 |
pg_shdepend | 1214 |
pg_type | 1247 |
pg_attribute | 1249 |
pg_proc | 1255 |
pg_class | 1259 |
pg_authid | 1260 |
pg_auth_members | 1261 |
pg_database | 1262 |
pg_foreign_server | 1417 |
pg_user_mapping | 1418 |
pg_foreign_data_wrapper | 2328 |
pg_shdescription | 2396 |
pg_aggregate | 2600 |
pg_am | 2601 |
pg_amop | 2602 |
pg_ampro | 2603 |
pg_attrdef | 2604 |
pg_cast | 2605 |
pg_constraint | 2606 |
pg_conversion | 2607 |
pg_depend | 2608 |
pg_description | 2609 |
pg_index | 2610 |
pg_inherits | 2611 |
pg_language | 2612 |
pg_largeobject | 2613 |
pg_namespace | 2615 |
pg_opclass | 2616 |
pg_operator | 2617 |
pg_rewrite | 2618 |
pg_stastic | 2619 |
pg_trigger | 2620 |
pg_opfamily | 2753 |
pg_db_role_setting | 2964 |
pg_largeobject_metadata | 2995 |
pg_extension | 3079 |
pg_foreign_table | 3118 |
pg_collation | 3456 |
pg_enum | 3501 |
pg_seclabel | 3596 |
pg_ts_dict | 3600 |
pg_ts_parser | 3601 |
pg_ts_config | 3602 |
pg_ts_config_map | 3603 |
pg_ts_template | 3764 |
然后,我还可以进一步,观察 ,把上述表格补充完整:
/* ----------------
* relation_open - open any relation by relation OID
*
* If lockmode is not "NoLock", the specified kind of lock is
* obtained on the relation. (Generally, NoLock should only be
* used if the caller knows it has some appropriate lock on the
* relation already.)
*
* An error is raised if the relation does not exist.
*
* NB: a "relation" is anything with a pg_class entry. The caller is
* expected to check whether the relkind is something it can handle.
* ----------------
*/
Relation
relation_open(Oid relationId, LOCKMODE lockmode)
{ fprintf(stderr,"___________________ In relation_open start by process %d\n",getpid()); Relation r; Assert(lockmode >= NoLock && lockmode < MAX_LOCKMODES); /* Get the lock before trying to open the relcache entry */
if (lockmode != NoLock)
LockRelationOid(relationId, lockmode); /* The relcache does all the real work... */
r = RelationIdGetRelation(relationId); fprintf(stderr,"In relation_open ,the relNode is:%d....\n\n",r->rd_node.relNode); if (!RelationIsValid(r))
elog(ERROR, "could not open relation with OID %u", relationId); /* Make note that we've accessed a temporary relation */
if (RelationUsesLocalBuffers(r))
MyXactAccessedTempRel = true; pgstat_initstats(r); fprintf(stderr,"___________________ In relation_open end by process %d\n",getpid()); return r;
}
加入了调试代码后,我可以看到,pg_tablespace 的 RelationId是 1213,而它的对应文件名是 12587。
下面,补充完整:
system table name | RelationId | FileName |
pg_default_acl | 826 | 12642 |
pg_pltemplate | 1136 | 12591 |
pg_tablespace | 1213 | 12587 |
pg_shdepend | 1214 | 12598 |
pg_type | 1247 | 12442 |
pg_attribute | 1249 | 12446 |
pg_proc | 1255 | 12458 |
pg_class | 1259 | 12465 |
pg_authid | 1260 | 12450 |
pg_auth_members | 1261 | 12594 |
pg_database | 1262 | 12692 |
pg_foreign_server | 1417 | 12635 |
pg_user_mapping | 1418 | 12454 |
pg_foreign_data_wrapper | 2328 | 12631 |
pg_shdescription | 2396 | 12602 |
pg_aggregate | 2600 | 12525 |
pg_am | 2601 | 12505 |
pg_amop | 2602 | 12509 |
pg_ampro | 2603 | 12514 |
pg_attrdef | 2604 | 12469 |
pg_cast | 2605 | 12549 |
pg_constraint | 2606 | 12476 |
pg_conversion | 2607 | 12562 |
pg_depend | 2608 | 12567 |
pg_description | 2609 | 12543 |
pg_index | 2610 | 12489 |
pg_inherits | 2611 | 12485 |
pg_language | 2612 | 12518 |
pg_largeobject | 2613 | 12571 |
pg_namespace | 2615 | 12558 |
pg_opclass | 2616 | 12501 |
pg_operator | 2617 | 12493 |
pg_rewrite | 2618 | 12528 |
pg_stastic | 2619 | 12436 |
pg_trigger | 2620 | 12535 |
pg_opfamily | 2753 | 12497 |
pg_db_role_setting | 2964 | 12581 |
pg_largeobject_metadata | 2995 | 12522 |
pg_extension | 3079 | 12627 |
pg_foreign_table | 3118 | 12639 |
pg_collation | 3456 | 12652 |
pg_enum | 3501 | 12553 |
pg_seclabel | 3596 | 12646 |
pg_ts_dict | 3600 | 12615 |
pg_ts_parser | 3601 | 12619 |
pg_ts_config | 3602 | 12608 |
pg_ts_config_map | 3603 | 12612 |
pg_ts_template | 3764 | 12623 |
如果进一步查看,还可以发现:
只有如下几个系统表的对应文件位于 global目录,其余的系统表的对应文件则是base目录下的每个子目录中都有(一个子目录对应一个数据库):
system table name | RelationId | FileName |
pg_pltemplate | 1136 | 12591 |
pg_tablespace | 1213 | 12587 |
pg_shdepend | 1214 | 12598 |
pg_authid | 1260 | 12450 |
pg_auth_members | 1261 | 12594 |
pg_database | 1262 | 12692 |
pg_shdescription | 2396 | 12602 |
pg_db_role_setting | 2964 | 12581 |
对PostgreSQL中 pg_各表的RelationId的认识的更多相关文章
- PostgreSQL中使用外部表
1. 安装file_fdw 需要先安装file_fdw,一般是进到PostgreSQL的源码包中的contrib/file_fdw目录下,执行: make make install 然后进入数据库中, ...
- PostgreSQL中数据库,表,等对象的oid与对象名的对应关系
-bash-4.1$ oid2name Password: All databases: Oid Database Name Tablespace--------------------------- ...
- PostgreSQL中关于关键字(保留字)在表名和字段名中的应用文件解决
标识符和关键词 受限标识符或被引号修饰的标识符.它是由双引号(")包围的一个任意字符序列.一个受限标识符总是一个标识符而不会是一个关键字.因此"select"可以用于引用 ...
- PostgreSQL 中日期类型转换与变量使用及相关问题
PostgreSQL中日期类型与字符串类型的转换方法 示例如下: postgres=# select current_date; date ------------ 2015-08-31 (1 row ...
- 在PostgreSQL中使用oracle_fdw访问Oracle
本文讲述如何在PostgreSQL中使用oracle_fdw访问Oracle上的数据. 1. 安装oracle_fdw 可以参照:oracle_fdw in github 编译安装oracle_fdw ...
- [转] PostgreSQL学习手册(数据表)
from: http://www.cnblogs.com/stephen-liu74/archive/2012/04/23/2290803.html 一.表的定义: 对于任何一种关系型数据库而言,表都 ...
- Postgresql中临时表(temporary table)的特性和用法
熟悉Oracle的人,相比对临时表(temporary table)并不陌生,很多场景对解决问题起到不错的作用,开源库Postgresql中,也有临时表的概念,虽然和Oracle中临时表名字相同,使用 ...
- Django中的跨表查询,多表查询。
一:Django中的ORM进行操作. 必须掌握的十三条: <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 & ...
- Postgresql中的数据类型大全
一.数值类型: 下面是PostgreSQL所支持的数值类型的列表和简单说明: 名字 存储空间 描述 范围 smallint 2 字节 小范围整数 -32768 到 +32767 integer 4 字 ...
随机推荐
- FFmpeg介绍及参数详细说明
FFmpeg是一个开源免费跨平台的视频和音频流方案,属于自由软件,采用LGPL或GPL许可证(依据你选择的组件).它提供了录制.转换以及流化音视频的完整解决方案.它包含了非常先进的音频/视频编解码库l ...
- UVa 11300 Spreading the Wealth 分金币
圆桌旁坐着 n 个人,每个人都有一定数量的金币,金币总数能够被 n 整除.每个人可以给他左右相邻的人一些金币,最终使得每个人的金币数目相等.你的任务是求出被转手的金币数量的最小值,比如 n = 4, ...
- hdu 1299 Diophantus of Alexandria
1/x + 1/y = 1/n 1<=n<=10^9给你 n 求符合要求的x,y有多少对 x<=y// 首先 x>n 那么设 x=n+m 那么 1/y= 1/n - 1/(n+ ...
- 【转】如何在IOS中使用3D UI - CALayer的透视投影
原文网址:http://www.tairan.com/archives/2041/ 例子代码可以在 http://www.tairan.com/thread-3607-1-1.html 下载 iOS的 ...
- [Papers]NSE, $\p_3u$, multiplier spaces [Guo-Gala, ANAP, 2013]
$$\bex \p_3\bbu\in L^\frac{2}{1-r}(0,T;\dot X_r(\bbR^3)),\quad 0\leq r\leq 1. \eex$$
- util-判断当前年份所处的季度,并返回当前季度开始的月份
ylbtech-funcation-util: 判断当前年份所处的季度,并返回当前季度开始的月份 判断当前年份所处的季度,并返回当前季度开始的月份. 1.A,Ylbtech.Model返回顶部 us ...
- Redis,Memcache,mongoDB的区别
从以下几个维度,对redis.memcache.mongoDB 做了对比,欢迎拍砖 1.性能 都比较高,性能对我们来说应该都不是瓶颈 总体来讲,TPS方面redis和memcache差不多,要大于mo ...
- 【原】Storm学习资料推荐
4.Storm学习资料推荐 书籍: 英文: Learning Storm: Ankit Jain, Anand Nalya: 9781783981328: Amazon.com: Books Gett ...
- C/C++:类模板
类模板就是为类声明一种模板,使得类中的某些数据成员,或某些成员函数的参数,又或者是某些成员函数的返回值可以取任意的数据类型,包括基本数据类型和自定义数据类型. 类模板的声明形式如下: template ...
- Fast Intro To Java Programming (2)
Java局部变量 局部变量声明在方法.构造方法或者语句块中: 局部变量在方法.构造方法.或者语句块被执行的时候创建,当它们执行完成后,变量将会被销毁: 访问修饰符不能用于局部变量: 局部变量只在声明它 ...