加入收藏 | 设为首页 | 会员中心 | 我要投稿 焦作站长网 (https://www.0391zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长资讯 > 动态 > 正文

PostgreSQL的外部数据封装器fdw办法

发布时间:2021-10-14 14:05:03 所属栏目:动态 来源:互联网
导读:数据封装器fdw(Foreign Data Wrappers)在PostgreSQL中相当于oracle中的dblink,可以很方便的操作其他数据库中的数据。 场景,在本地的test库中通过外部数据封

数据封装器fdw(Foreign Data Wrappers)在PostgreSQL中相当于oracle中的dblink,可以很方便的操作其他数据库中的数据。

 

场景,在本地的test库中通过外部数据封装器fdw访问本地的testdb中的t2表

 

本地库test用户u1,远程库test用户dbuser

 

版本:

 

postgres=# select version();

             version

------------------------------------------------------------

 PostgreSQL 11.1, compiled by Visual C++ build 1914, 64-bit

(1 行记录)

 

 

 

1,安装postgres_fdw扩展与授权

 

1CREATE EXTENSION postgres_fdw;

 

如果需要授权

 

1grant usage on foreign data wrapper postgres_fdw to u1;

 

2,然后使用CREATE SERVER创建一个外部服务器。

 

CREATE SERVER foreign_server

    FOREIGN DATA WRAPPER postgres_fdw

    OPTIONS (host '127.0.0.1', port '5432', dbname 'testdb');

 

 

 

3,用CREATE USER MAPPING 定义的用户映射来标识将在远程服务器上使用的角色:

 

CREATE USER MAPPING FOR public

    SERVER foreign_server

    OPTIONS (user 'dbuser', password '123456');

 

4,用CREATE FOREIGN TABLE创建外部表了。

 

在这个例子中我们希望访问远程服务器上名为 some_schema.some_table的表。它的本地名称是 foreign_table,注意结构要对应

 

CREATE FOREIGN TABLE foreign_table_t2(id int,name varchar(10))

SERVER foreign_server options(schema_name 'public',table_name 't2');

 

 

 

这样就可以通过foreign_table_t2来操作远程的表t2了

 

当然可以使用oracle_fdw,mysql_fdw,tds_fdw,redis_fdw等来操作别的数据库

 

补充:PostgreSQL数据库插件fdw使用心得—mysql_fdw、oracle_fdw、postgresql_fdw

 

fdw是foreign data wrapper的一个简称,叫做外部封装数据。

 

用命令行登陆postgresql:

 

plsql -h ip地址 -p 端口号 -U 用户名 -d 库名

 

1、安装fdw

 

fdw工具是pg自带扩展工具,pg10版本之后不需要再单独安装,一般分为postgresql_fdw、mysql_fdw、file_fdw、oracle_fdw等。可以将不同的异构数据源当成pg的外表。

 

2、创建库连接

 

postgresql_fdw

 

一. 创建postgres_fdw扩展(仅需第一次执行):

 

-- 创建postgresql_fdw扩展

-- Foreign Data Wrapper: postgres_fdw

CREATE FOREIGN DATA WRAPPER postgres_fdw

 

-- 删除该扩展

-- DROP FOREIGN DATA WRAPPER postgres_fdw

 

 

 

-- 删除该扩展-- DROP FOREIGN DATA WRAPPER postgres_fdw

 

二. 创建远程服务器,这里需要定义远程主机ip、数据库库名、端口号(同一个远程数据库只需执行一次):

 

-- 创建ods_server服务对接远程数据库的ods_db库

-- Foreign Server: ods_server

CREATE SERVER ods_server

  FOREIGN DATA WRAPPER postgres_fdw

  OPTIONS (host '68.26.1.1', dbname 'ods_db', port '5432');

 

-- 删除该服务 

-- DROP SERVER ods_server;

(编辑:焦作站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读