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');