postgres表空间和os的文件的对应关系

postgres 自带了两个表空间,pg_default, pg_global
表空间pg_default是用来存储系统目录对象、用户表、用户表index、和临时表、临时表index、内部临时表的默认空间。对应存储目录 P A D A T A / b a s e / 表 空 间 p g g l o b a l 用 来 存 放 系 统 字 典 表 ; 对 应 存 储 目 录 PADATA/base/ 表空间pg_global用来存放系统字典表;对应存储目录 PADATA/base/pgglobalPADATA/global/

pgsql 中表空间/数据库/模式 的关系:

  1. 表空间是物理结构,同一表空间下可以有多个数据库
  2. 数据库是逻辑结构,是表/索引/视图/存储过程的集合,一个数据库下可以有多个schema
  3. 模式是逻辑结构,是对数据库的逻辑划分

数据库以oid方式在base目录下存放。

postgres=# select * from pg_tablespace;
 oid  |  spcname   | spcowner | spcacl | spcoptions 
------+------------+----------+--------+------------
 1663 | pg_default |       10 |        | 
 1664 | pg_global  |       10 |        | 
(2 rows)

root@scutech:/var/lib/postgresql/12/main# du -h base
7.8M	base/1
11M	base/16386
11M	base/13432
7.7M	base/13431
7.8M	base/16385
45M	base
root@scutech:/var/lib/postgresql/12/main# 
postgres=# select oid, datname, datlastsysoid, dattablespace from pg_catalog.pg_database order by 1,2;
  oid  |  datname  | datlastsysoid | dattablespace 
-------+-----------+---------------+---------------
     1 | template1 |         13431 |          1663
 13431 | template0 |         13431 |          1663
 13432 | postgres  |         13431 |          1663
 16385 | test      |         13431 |          1663
 16386 | mydb      |         13431 |          1663
(5 rows)

文章下方是我的微信,欢迎加我。👇

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

姚远Oracle ACE

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值