在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
之前在CSDN阅读资料时,发现有人问怎么把 postgresql数据库 的表 跟TimescaleDB 时序库的表 join在一起,正好我在查询数据的时候遇到过这个问题 ,我说一下我的解决方案 ** 一 安装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数据库)** 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 ,是删不掉的,报错如下:
** 三 创建外部表** 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相应的模式下,需指定模式 DROP FOREIGN TABLE tb_fdw_timescale_target; ** 四 检查外部表** 这个错误就是你之前配置要连接的TimescaleDB数据库 配置错误了,改的话我目前知道的是只能级联删除fdw,重新建了 当然 fdw的功能远远不止这些,还可以很Mysql数据库,oracle等数据库 到此这篇关于postgresql 数据库 与TimescaleDB 时序库 join 在一起的文章就介绍到这了,更多相关postgresql与TimescaleDB 时序库 join内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论