暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

通过postgres_fdw实现跨库访问

瀚高PG实验室 2022-11-02
679

目录

文档用途

详细信息

文档用途

介绍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);

    (左右滑动查看完整内容)

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

      (左右滑动查看完整内容)

      查看插入数据量

      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的外联表

            文章转载自瀚高PG实验室,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

            评论