postgres使用postgres_fdw实现跨库查询

postgres使用postgres_fdw实现跨库查询
1.创建postgres_fdw
// 创建
create extension postgres_fdw;
//查询是否创建成功
select * from pg_available_extensions; 
2.创建远程server

server_remote是给这个远程server取得名字。options中是连接远程server需要的信息,包括地址、端口和需要连接的数据库名。

create server server_remote 
FOREIGN data wrapper postgres_fdw 
OPTIONS(host '10.191.1.1', port '5432', dbname 'systst');
//验证server创建成功。
SELECT * from pg_foreign_server;
3.创建用户匹配信息

创建一个用户和远程服务相匹配的,options里是用户名和密码。(远程服务的用户)

create user mapping for postgres server server_remote options(user 'postgres',password 'postgres');
 // 验证是否创建成功
select * from pg_user_mappings
// 如果创建的不匹配 导致下一步无法导入表格,报密码或者用户错误时,可将创建的用户删除,从新创建过
DROP USER MAPPING IF EXISTS  FOR  postgres  SERVER server_remote ;
4.创建forein table

方法一: 批量导入,这种比较常见,可以一次导入一个模式下的所有表

import foreign schema public   from server server_remote into public;

方法二: 单个创建 t1为远程服务中的表

CREATE FOREIGN TABLE t1 (id int, info text) server server_remote OPTIONS (schema_name 'public', table_name 't1');
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值