之前在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等数据库
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。