OpenGauss配置FDW外部表

本文介绍了如何在OpenGauss环境中通过创建外连接和服务器,实现172.32.148.154机器对155机器postgres数据库的访问。重点展示了如何配置postgres_fdw扩展、服务器和用户映射,以及如何在154机器上进行事务操作,实现对远程表的并发控制特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设IP为172.32.148.154的OpenGauss机器连接IP为172.32.148.155的机器,查询155中的表public.emp,155的端口号为31001,数据库名postgres,用户postgres/Postgres123:

在154机器上执行:

CREATE EXTENSION postgres_fdw;

CREATE SERVER foreign_server FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host '172.32.148.155', port '31001', dbname 'postgres');

在155机器上执行:
gs_guc generate -S Postgres123 -D $GAUSSHOME/bin -o usermapping

在154机器上执行:

CREATE USER MAPPING FOR postgres SERVER foreign_server OPTIONS (user 'postgres', password 'Postgres123');

CREATE FOREIGN TABLE femp (
empno int,
ename varchar(10),
job varchar(9),
mgr numeric(4),
hiredate date,
sal numeric(7,2),
comm numeric(7,2),
deptno numeric(2)
)
SERVER foreign_server
OPTIONS (schema_name 'public', table_name 'emp');

然后就可以在154上查询femp,femp和154上的本地表JOIN,令人吃惊的是,可以在154上将femp包含在事务中,其中对femp的未提交修改,并不会写到155上,就好像154的femp表做了缓存一样,只有154上commit时,155上才会修改,好像跨机器实现了事务的并发控制。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值