因为项目上的需要,开始使用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.<表名>