mysql和timescale联合查询_postgresql 数据库 与TimescaleDB 时序库 join 在一起

本文介绍如何利用PostgreSQL的fdw功能实现与TimescaleDB时序数据库的表联接。通过安装插件、创建外部连接及表,最终实现数据查询。适用于需要整合两种数据库场景。

之前在优快云阅读资料时,发现有人问怎么把 postgresql数据库 的表 跟TimescaleDB 时序库的表 join在一起,正好我在查询数据的时候遇到过这个问题 ,我说一下我的解决方案

我选择的是postgresql数据库的fdw功能(postgres_fdw插件)

**

一 安装postgres_fdw插件

1.1安装postgres_fdw插件

**

su – postgres

-bash-4.2$ psql

postgres=# \c hrmwv2 #(数据库名字)

Create extension "postgres_fdw";

也可以在连接数据库的工具中执行

71d3181c5292ae98cbaba53759da9e39.png

1.2 查看已安装插件命令

select * from pg_available_extensions;

**

二 创建外部连接(TimescaleDB数据库)

**

需要连接TimescaleDB数据库 信息:(虚构)

ip :170.0.0.32 端口:5432

数据库名: hrmw 用户名:postgres

2.1创建于TimescaleDB的外部链接

--创建外部服务器

-- 括号里的三个参数,分别是timescaledb的ip、端口和数据库名称

CREATE SERVER timescale_db FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host '170.0.0.32', port '5432', dbname 'hrmw');

--创建用户映射

-- 括号里的两个参数,分别是timescaledb数据库的用户名、密码

create user mapping for postgres server timescale_db options(user 'postgres', password '数据库密码');

2.2 查看外部链接命令

select * from pg_foreign_server;

结果:

49b2fd3238a55abb2fa0e6554b79a76b.png

#一般fwd出问题就看看这里 是否配置正确

srvname:--你建的链接名

srvoptions:--你要链接的timescaledb时序库的信息

2.3 删除fdw外部链接

这里删除要一步步的删或者直接使用级联删除的方法

drop server timescale_db CASCADE;

如果不用级联,直接drop timescale_db ,是删不掉的,报错如下:

> ERROR:  cannot drop server timescale_db because other objects depend on it

DETAIL:  user mapping for postgres on server timescale_db depends on server timescale_db

HINT:  Use DROP ... CASCADE to drop the dependent objects too.

**

三 创建外部表

**

3.1 创建外部表(你需要join TimescaleDB的 那张表:一模一样的,可以是超表)

CREATE FOREIGN TABLE tb_fdw_timescale_target

(

collect_time timestamp(6),

id varchar(36) ,

value numeric(12,2) ,

file_no int4 ,

create_time timestamp(6)

)

server timescale_db --你创建的外部链接名字

options (table_name '时序库的表名');

如果你没有进到pg相应的模式下,需指定模式

3.2 删除外部表命令

跟普通表一样

DROP FOREIGN TABLE tb_fdw_timescale_target;

**

四 检查外部表

**

去业务打开你建的外部表是否有数据, 如果有数据则表明外部表创建成功,你就可以跟业务库的一起join了

d31db64cecc174e397e5294847624c5f.png

这个错误就是你之前配置要连接的TimescaleDB数据库 配置错误了,改的话我目前知道的是只能级联删除fdw,重新建了

当然 fdw的功能远远不止这些,还可以很Mysql数据库,oracle等数据库

到此这篇关于postgresql 数据库 与TimescaleDB 时序库 join 在一起的文章就介绍到这了,更多相关postgresql与TimescaleDB 时序库 join内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值