postgresql 数据库 与TimescaleDB 时序库 join 在一起

 更新时间:2020年12月29日 09:05:33   作者:yang_z_1  
这篇文章主要介绍了postgresql 数据库 与TimescaleDB 时序库 join 在一起,需要的朋友可以参考下

之前在CSDN阅读资料时,发现有人问怎么把 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";

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

在这里插入图片描述

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;

结果:

在这里插入图片描述

#一般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了

在这里插入图片描述

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

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

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

相关文章

  • PostgreSQL标准建表语句分享

    PostgreSQL标准建表语句分享

    这篇文章主要介绍了PostgreSQL标准建表语句分享,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • 常用 PostgreSQL 预防数据丢失解决方案

    常用 PostgreSQL 预防数据丢失解决方案

    这篇文章主要介绍了常用 PostgreSQL 预防数据丢失方案,本篇主要介绍关于 DDL 和 DML 操作,如何预防数据丢失的方案,需要的朋友可以参考下
    2022-01-01
  • 基于PostgreSql 别名区分大小写的问题

    基于PostgreSql 别名区分大小写的问题

    这篇文章主要介绍了基于PostgreSql 别名区分大小写的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Postgresql 如何选择正确的关闭模式

    Postgresql 如何选择正确的关闭模式

    这篇文章主要介绍了Postgresl 如何选择正确的关闭模式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL时间线(timeline)和History File的用法

    PostgreSQL时间线(timeline)和History File的用法

    这篇文章主要介绍了PostgreSQL时间线(timeline)和History File的用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL 实现sql放入文件批量执行

    PostgreSQL 实现sql放入文件批量执行

    这篇文章主要介绍了PostgreSQL 实现sql放入文件批量执行,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • postgresql行转列与列转行图文教程

    postgresql行转列与列转行图文教程

    PostgreSQL是一种开源的关系型数据库,它提供了多种管理工具来操作数据库,下面这篇文章主要给大家介绍了关于postgresql行转列与列转行的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • pgsql批量修改sequences的start方式

    pgsql批量修改sequences的start方式

    这篇文章主要介绍了pgsql批量修改sequences的start方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL pg_ctl start启动超时实例分析

    PostgreSQL pg_ctl start启动超时实例分析

    这篇文章主要给大家介绍了关于PostgreSQL pg_ctl start启动超时的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • postgresql 如何关闭自动提交

    postgresql 如何关闭自动提交

    这篇文章主要介绍了postgresql 如何关闭自动提交的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论