数据封装器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