首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用表空间中的数据填充另一个postgres数据库实例,而不实际插入

使用表空间中的数据填充另一个postgres数据库实例,而不实际插入
EN

Database Administration用户
提问于 2012-12-10 10:41:42
回答 1查看 425关注 0票数 0

我有一个postgres数据库(8.4版本),有许多表。有些表的大小很大,但数据是静态的(在任何实例中都是常见的)。我已经将这样的表存储在单独的表空间中。有没有办法使用这些现有的数据。或者我是否可以创建另一个数据库实例(可能在单独的服务器上)并创建空的bigTable并指向现有的表空间来填充现有的bigTable中的数据?

我是否可以使用表空间中的现有数据填充到另一个postgres数据库实例中,而无需实际插入数据,因为重新插入整个数据需要很长时间。

我尝试更新pg_class表以指向现有的reltablespacerelfilenode。但是它并没有完全帮助我,因为我无法更改数据库OID。是否有一种方法可以使用相同的数据库OID在另一个数据库服务器上创建一个数据库实例?

EN

回答 1

Database Administration用户

发布于 2012-12-10 11:00:28

表属于一个数据库。句号。可以在同一数据库集群的数据库之间共享表空间,但不能共享表。

但是,您可以将dblink用于您想要的内容。通过这种方式,您可以从不同的数据库--甚至来自不同服务器上的不同DB-集群中查询表。同一服务器上的简单SELECT查询非常快速。试试这个搜索用于代码示例。

或者查看CREATE FOREIGN TABLE获得非常类似的功能。现在,我更喜欢dblink,因为它已经成熟且稳定。新的SQL/MED特性(外部数据管理)、FOREIGN DATA WRAPPERFOREIGN TABLE仍在酝酿之中。

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/30088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档