服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - PostgreSQL - postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

2021-04-18 22:39yang_z_1 PostgreSQL

这篇文章主要介绍了postgresql 利用fdw来实现不同数据库之间数据互通,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

前言
最近在工作的时候 需要用数据库a中的表a1来更新插入数据库b中的b2表 由于数据库都是postgres数据库
我想到了 postgres_fdw插件

准备工作
首先需要保证这两个数据库之间网 是通的

数据库a 名字 aa ip 10.10.2.100(虚构)端口 5432 用户名 postgres
数据库b 名字 bb ip 100.20.0.120(虚构)端口 6688 用户名 postgres

一 利用fdw创建2个数据库之间的连接

 

1.1 安装 postgres_fdw插件

?
1
create extension "postgres_fdw";

 

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

1.2 创建外部连接

无论你实在a数据库中创建b数据库的连接 ,还是在b数据库中创建a数据库的连接 从本质上是一样的,都是为了打通2个数据库,实现数据互通
1.2.1 在a数据库创建b数据库的连接

?
1
2
3
4
5
6
--创建外部服务器
-- 括号里的三个参数,分别是数据库b的ip、端口和数据库名称
create server lianjiebb foreign data wrapper postgres_fdw options (host '100.20.0.120', port '6688', dbname 'bb');
--创建用户映射·
-- 括号里的两个参数,分别是数据库b数据库的用户名、密码
create user mapping for postgres server lianjiebb options(user 'postgres', password '数据库密码');

1.2.2 在b数据库创建a数据库的连接

?
1
2
3
4
5
6
--创建外部服务器
-- 括号里的三个参数,分别是数据库a的ip、端口和数据库名称
create server lianjieaa foreign data wrapper postgres_fdw options (host '10.10.2.100', port '5432', dbname 'aa');
--创建用户映射·
-- 括号里的两个参数,分别是数据库a数据库的用户名、密码
create user mapping for postgres server lianjieaa options(user 'postgres', password '数据库密码');

1.2.3 查询 外部链接

?
1
select * from pg_foreign_server;

1.3 创建外部表

在a数据库创建b1表的外部链接

?
1
2
3
4
5
6
7
8
9
10
create foreign table tb_fdw_b1
 (
 collect_time timestamp(6),
 id varchar(36) ,
 列名1 numeric(12,2) ,
 列名2 int4 ,
列名3 timestamp(6)
 ) --跟b1 一模一样的表结构就行
 server lianjiebb --你创建的外部链接名字
 options (table_name '时序库的表名');

查看外部表是否有数,有数就表示ok了

?
1
select * from tb_fdw_b1;

在数据库b上创建a1表的外部链接也是一样的

二 插入数据

 

2.1 往外部表tb_fdw_b1 插入表a1的数据

因为 俩个表都是一样的表结构,可以直接插入

?
1
insert into tb_fdw_b1 select * from a1;

因为外部表是实时的 在数据库a中更改了 外部表tb_fdw_b1 的数据 ,数据库b中的b1表中的数据也随之改变 达成了我们一开始的目的

更新 update 删除delete 也是一样的 在这里就不说了

三 利用定时任务来达成自动同步

 

每天都需要执行显然不符合我们的“懒人”形象 ,所以用定时任务来实现明天自动同步是必不可少的 我让他每天早上8点自动执行

3.1 利用 pgadmin实现定时同步(截图)

3.1.1

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

3.1.2

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

3.1.3

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

3.1.4

postgresql 利用fdw来实现不同数据库之间数据互通(推荐)

3.2 直接上语句实现定时同步

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
do $$
declare
 jid integer;
 scid integer;
begin
-- creating a new job
insert into pgagent.pga_job(
 jobjclid, jobname, jobdesc, jobhostagent, jobenabled
) values (
 1::integer, '更新表b1'::text, ''::text, ''::text, true
) returning jobid into jid;
 
-- steps
-- inserting a step (jobid: null)
insert into pgagent.pga_jobstep (
 jstjobid, jstname, jstenabled, jstkind,
 jstconnstr, jstdbname, jstonerror,
 jstcode, jstdesc
) values (
 jid, '更新表b1'::text, true, 's'::character(1),
 ''::text, '数据库a'::name, 'f'::character(1),
 ' insert into tb_fdw_b1 select * from a1;'::text, ''::text
) ;
 
-- schedules
-- inserting a schedule
insert into pgagent.pga_schedule(
 jscjobid, jscname, jscdesc, jscenabled,
 jscstart, jscend, jscminutes, jschours, jscweekdays, jscmonthdays, jscmonths
) values (
 jid, '更新表b1'::text, ''::text, true,
 '2021-02-07 10:24:50 +08:00'::timestamp with time zone, '2100-02-07 10:24:52 +08:00'::timestamp with time zone,
 -- minutes
 array[true,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false]::boolean[],
 -- hours
 array[false,false,false,false,false,false,false,false,true,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false]::boolean[],
 -- week days
 array[false,false,false,false,false,false,false]::boolean[],
 -- month days
 array[false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false]::boolean[],
 -- months
 array[false,false,false,false,false,false,false,false,false,false,false,false]::boolean[]
) returning jscid into scid;
end
$$;

到此这篇关于postgresql 利用fdw来实现不同数据库之间数据互通的文章就介绍到这了,更多相关postgresql实现数据互通内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/yang_z_1/article/details/113735277

延伸 · 阅读

精彩推荐
  • PostgreSQLpostgresql 数据库中的数据转换

    postgresql 数据库中的数据转换

    postgres8.3以后,字段数据之间的默认转换取消了。如果需要进行数据变换的话,在postgresql数据库中,我们可以用"::"来进行字段数据的类型转换。...

    postgresql教程网12482021-10-08
  • PostgreSQLPostgreSQL标准建表语句分享

    PostgreSQL标准建表语句分享

    这篇文章主要介绍了PostgreSQL标准建表语句分享,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    码上得天下7962021-02-27
  • PostgreSQL深入理解PostgreSQL的MVCC并发处理方式

    深入理解PostgreSQL的MVCC并发处理方式

    这篇文章主要介绍了深入理解PostgreSQL的MVCC并发处理方式,文中同时介绍了MVCC的缺点,需要的朋友可以参考下 ...

    PostgreSQL教程网3622020-04-25
  • PostgreSQLPostgresql开启远程访问的步骤全纪录

    Postgresql开启远程访问的步骤全纪录

    postgre一般默认为本地连接,不支持远程访问,所以如果要开启远程访问,需要更改安装文件的配置。下面这篇文章主要给大家介绍了关于Postgresql开启远程...

    我勒个去6812020-04-30
  • PostgreSQLPostgresql查询效率计算初探

    Postgresql查询效率计算初探

    这篇文章主要给大家介绍了关于Postgresql查询效率计算的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Postgresql具有一定的参考学习价...

    轨迹4622020-05-03
  • PostgreSQL分布式 PostgreSQL之Citus 架构

    分布式 PostgreSQL之Citus 架构

    节点 Citus 是一种 PostgreSQL 扩展,它允许数据库服务器(称为节点)在“无共享(shared nothing)”架构中相互协调。这些节点形成一个集群,允许 PostgreSQL 保存比单...

    未知802023-05-07
  • PostgreSQLpostgresql 中的to_char()常用操作

    postgresql 中的to_char()常用操作

    这篇文章主要介绍了postgresql 中的to_char()常用操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    J符离13432021-04-12
  • PostgreSQLRDS PostgreSQL一键大版本升级技术解密

    RDS PostgreSQL一键大版本升级技术解密

    一、PostgreSQL行业位置 (一)行业位置 在讨论PostgreSQL(下面简称为PG)在整个数据库行业的位置之前,我们先看一下阿里云数据库在全球的数据库行业里的...

    未知1192023-05-07