• 通过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);
    
    • 1

    在这里插入图片描述

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

    在这里插入图片描述

    查看插入数据量

    在这里插入图片描述

    2、数据库B查看表并创建扩展
    在这里插入图片描述

    在这里插入图片描述

    查看扩展创建情况
    在这里插入图片描述

    3、通过fdw创建外联服务

    CREATE SERVER table1 
    
             FOREIGN DATA WRAPPER postgres_fdw 
    
             OPTIONS (host '192.168.80.131', port '5432', dbname 'postgres');
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    4、创建外联用户信息

    CREATE USER MAPPING FOR postgres 
    
     SERVER table1 
    
     OPTIONS (user 'postgres', password 'highgo@123');
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    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');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    查看数据库B的外联表
    在这里插入图片描述

    在这里插入图片描述

  • 相关阅读:
    ES6面向对象思想和构造对象方式
    mac 中配置idea自带maven环境变量
    实用篇-ES环境搭建
    I/O 模型解析
    【生活】如何学习理财
    FDTD自定义材料
    二十四、MySQL事务操作演示
    Nhanes临床数据库挖掘教程2—基线表绘制(table1)
    面向对象开发技术设计模式的选择
    第一课 概念介绍
  • 原文地址:https://blog.csdn.net/pg_hgdb/article/details/128188110