通过postgres_fdw实现跨库访问

Posted 瀚高PG实验室

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了通过postgres_fdw实现跨库访问相关的知识,希望对你有一定的参考价值。

瀚高数据库
目录
文档用途
详细信息

介绍Postgresql跨库访问中postgres_fdw的使用方法

详细信息
PostgreSQL 外部数据包装器,即 PostgreSQL Foreign Data Wrappers,是现实数据库使用场景中一个非常实用的功能,PostgreSQL 的 FDW 类似于 Oracle 的 dblink,DB2 的 Federation,使用其可以将本地数据库与外部数据库建立连接,从而可以像操作本地数据一样来操作外部数据。

postgrs_fdw是PostgreSQL 外部数据包装器中的一种,可用于访问储存在外部postgresql数据库的数据。

使用步骤如下:

1、使用 CREATE EXTENSION 来安装 postgres_fdw扩展。

2、使用 CREATE SERVER 创建一个外部服务器对象,它用来表示你想连接的每一个远程数据库。指定除了 user 和 password 之外的连接信息作为该服务器对象的选项。

3、使用 CREATE USER MAPPING 创建一个用户映射,每一个用户映射都代表你想允许一个数据库用户访问一个外部服务器。指定远程用户名和口令作为用户映射的 user 和 password 选项。

4、为每一个你想访问的远程表使用 CREATE FOREIGN TABLE 或者 IMPORT FOREIGN SCHEMA 创建一个外部表。外部表的列必须匹配被引用的远程表。但是,如果你在外部表对象的选项中指定了正确的远程名称,你可以使用不同于远程表的表名和/或列名。

示例

1、在数据库A创建测试表添加测试数据。

create table table1 (id int, crt_Time timestamp, info text, c1 int);

insert into table1 select generate_series(1,1000000), clock_timestamp(), md5(random()::text), random()*1000;

查看插入数据量

2、数据库B查看表并创建扩展

查看扩展创建情况

3、通过fdw创建外联服务

CREATE SERVER table1 

         FOREIGN DATA WRAPPER postgres_fdw 

         OPTIONS (host '192.168.80.131', port '5432', dbname 'postgres');

4、创建外联用户信息

CREATE USER MAPPING FOR postgres 

 SERVER table1 

 OPTIONS (user 'postgres', password 'highgo@123');

5、查看外联服务

6、将数据库A模式中的所有表在数据库B中创建外联表

查看数据库B的外联表

7、创建单个外联表

CREATE FOREIGN TABLE table2 ( 

    id int, crt_Time timestamp, info text, c1 int)  

          SERVER table1 

        OPTIONS (schema_name 'public', table_name 'table1');

查看数据库B的外联表

以上是关于通过postgres_fdw实现跨库访问的主要内容,如果未能解决你的问题,请参考以下文章

通过postgres_fdw实现跨库访问

PostgreSQL数据库中跨库访问解决方案

Postgresql 外部表插件postgres_fdw的安装和使用

SQL Server跨库跨服务器访问实现

postgres_fdw 无法连接到 Amazon RDS 上的服务器

EF跨库查询,DataBaseFirst下的解决方案