• 售前

  • 售后

热门帖子
入门百科

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

[复制链接]
123456823 显示全部楼层 发表于 2021-10-26 13:13:46 |阅读模式 打印 上一主题 下一主题
之前在CSDN阅读资料时,发现有人问怎么把 postgresql数据库 的表 跟TimescaleDB 时序库的表 join在一起,恰好我在查询数据的时候碰到过这个题目 ,我说一下我的办理方案
我选择的是postgresql数据库的fdw功能(postgres_fdw插件
**
一 安装postgres_fdw插件

1.1安装postgres_fdw插件
**
  1. su – postgres
  2. -bash-4.2$ psql
  3. postgres=# \c hrmwv2 #(数据库名字)
  4. Create extension "postgres_fdw";
复制代码
也可以在毗连数据库的工具中实验

1.2 检察已安装插件下令
  1. select * from pg_available_extensions;
复制代码
**
二 创建外部毗连(TimescaleDB数据库)

**
必要毗连TimescaleDB数据库 信息:(假造)
ip :170.0.0.32 端口:5432
数据库名: hrmw 用户名:postgres
2.1创建于TimescaleDB的外部链接
  1. --创建外部服务器
  2. -- 括号里的三个参数,分别是timescaledb的ip、端口和数据库名称
  3. CREATE SERVER timescale_db FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host '170.0.0.32', port '5432', dbname 'hrmw');
  4. --创建用户映射
  5. -- 括号里的两个参数,分别是timescaledb数据库的用户名、密码
  6. create user mapping for postgres server timescale_db options(user 'postgres', password '数据库密码');
复制代码
2.2 检察外部链接下令
  1. select * from pg_foreign_server;
复制代码
效果:
  1. #一般fwd出问题就看看这里 是否配置正确
  2. srvname:--你建的链接名
  3. srvoptions:--你要链接的timescaledb时序库的信息
复制代码
2.3 删除fdw外部链接
这里删除要一步步的删或者直接利用级联删除的方法
  1. drop server timescale_db CASCADE;
复制代码
假如不消级联,直接drop timescale_db ,是删不掉的,报错如下:
  1. > ERROR:  cannot drop server timescale_db because other objects depend on it
  2. DETAIL:  user mapping for postgres on server timescale_db depends on server timescale_db
  3. HINT:  Use DROP ... CASCADE to drop the dependent objects too.
复制代码
**
三 创建外部表

**
3.1 创建外部表(你必要join TimescaleDB的 那张表:千篇一律的,可以是超表)
  1. CREATE FOREIGN TABLE tb_fdw_timescale_target
  2. (
  3. collect_time timestamp(6),
  4. id varchar(36) ,
  5. value numeric(12,2) ,
  6. file_no int4 ,
  7. create_time timestamp(6)
  8. )
  9. server timescale_db --你创建的外部链接名字
  10. options (table_name '时序库的表名');
复制代码

假如你没有进到pg相应的模式下,需指定模式
3.2 删除外部表下令
跟平常表一样
  1. DROP FOREIGN TABLE tb_fdw_timescale_target;
复制代码
**
四 查抄外部表

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

这个错误就是你之前设置要毗连的TimescaleDB数据库 设置错误了,改的话我目前知道的是只能级联删除fdw,重新建了
当然 fdw的功能远远不止这些,还可以很Mysql数据库,oracle等数据库
到此这篇关于postgresql 数据库 与TimescaleDB 时序库 join 在一起的文章就先容到这了,更多相干postgresql与TimescaleDB 时序库 join内容请搜刮脚本之家从前的文章或继承欣赏下面的相干文章希望各人以后多多支持脚本之家!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作