PostgreSQL的跨库访问:postgres_fdw

因为项目上的需要,开始使用postgreSQL+postGIS数据库,但遇到了跨库访问的问题,经过查找资料并结合项目情况,最终选择了使用postgres_fdw的方式来实现跨库访问,所以这里记录下postgres_fdw的使用方法,以供查阅······

* 所有操作均在本地数据库上执行

1.创建postgres_fdw扩展插件

使用超级用户登录到本地数据库,执行语句:

create extension postgres_fdw;

2.创建外部数据库连接server

语句格式:

create server <server名称>
        foreign data wrapper postgres_fdw
        options (host '<远程数据库主机名>’, port '<远程数据库端口>', dbname '<远程数据库名称>');

exp:创建一个外部数据库连接服务geodata_link,这个数据库在主机192.168.88.2上,端口为5432,数据库是geodata

create server geodata_link 
    foreign data wrapper postgres_fdw 
    options (host '192.168.88.2’, port '5432', dbname 'geodata');

3.为本地用户创建用户映射user mapping

语句格式:

create user mapping for <本地数据库用户>
        server <server名称>
        options (user '<远程数据库用户>', password '<远程数据库用户密码>');

exp:为本地数据库用户gwgis在外部数据库连接服务geodata_link上创建用户映射,对应了远程数据库的gis用户

create user mapping for gwgis 
    server geodata_link
    options (user 'gis', password '123456');

4.导入远程数据库表

语句格式:

import foreign schema <远程数据库schema名称>
        from <server名称> 
        into <本地数据库schema名称>;

exp:将远程数据库public模式下的表导入到本地数据库的sde模式下

import foreign schema public 
    from server geodata_link 
    into sde;

 

完成以上步骤后,就可以在本地数据库里访问远程数据库,因为我是把外部表导入了名为sde的模式下,所以查询的格式为:

select * from sde.<表名> 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值