• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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 数据库 TimescaleDB 修改分区时间范围
    • postgresql数据库 timescaledb 时序库 把大数据量表转换为超表的问题
    上一篇:PostgreSQL之pgdump备份恢复操作
    下一篇:pgsql添加自增序列、设置表某个字段自增操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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