前言
这几天工作的时候发现在 timescaledb 时序库 中有部分大数据量的表不是超表,估计是当时建库的时候没有改 影响插入,查询效率 ,因此需要改成超表
因工作原因 部分内容做保密处理了
一 创建新表
首先因为在 timescaledb 时序库 中创建超表必须是要没有数据的表
因此第一步是 创建一张跟原表一模一样的表(表名后面加个_cs) 你可以直接copy建表语句,也可以直接用工具复制表结构
二 把新表改为超表
把新建的表改为超表,7天一分区
--我是7天一分区 SELECT create_hypertable('表名_cs', 'alarm_time', chunk_time_interval => INTERVAL '7 day'); -- 加个索引 CREATE INDEX "表名_cs_create_time_idx" ON "hrmw"."表名_cs" USING btree ( "create_time" "code"."列名" DESC NULLS FIRST );
三 插入数据
1.数据量不大的情况可以直接插入
INSERT into 表名_cs SELECT * from 表名;
2.如果数据量比较大 可以采取 一天一天 插入 或者一个月 或者几个月一起插入
INSERT into 表名_cs SELECT * from 表名 where alarm_time >= '2020-9-1'; INSERT into 表名_cs SELECT * from 表名 where alarm_time >= '2020-10-1' and alarm_time < '2020-11-1' ;
3.运用函数(储存过程)
对于表数据量太大,一天一天的插入的话 可以运用储存过程(postgresql 数据库叫函数)
下面是我写的函数。大家可以借鉴
CREATE OR REPLACE PROCEDURE "hrmw"."sp_into_表名_pt" ( ) AS $BODY$ BEGIN -- 一般按照表名来建函数 DECLARE --我声明的变量有点多 按实际的来 target_text TEXT; sqltext TEXT; sqltext1 TEXT; sqltext2 TEXT; rd record; nloop INT; isexist TEXT; datestr TEXT; begindate TEXT; n INT; BEGIN --查询最早一天的时间 sqltext := 'select to_char(min(alarm_time),''yyyy-mm-dd'') datestr from tb_hrmw_moni_target'; EXECUTE sqltext INTO begindate; n := date_part( 'day', now( ) - begindate :: DATE ); --enddate:=(to_char(now(),'yyyy-mm-dd'))::text; FOR nloop IN 0..n LOOP datestr := ( begindate :: DATE + nloop ) :: TEXT; sqltext2 := ' insert into 表名_cs select 列名1, code, 列名2, alarm_time, 列名3, 列名4 from 表名 where alarm_time >= ''' || datestr || ' 00:00:00'' and alarm_time <= ''' || datestr || ' 23:59:59'' '; EXECUTE sqltext2; COMMIT; END loop; RETURN; END; END $BODY$ LANGUAGE plpgsql
四 查看效果
模式 _timescaledb_internal下面的就是分区
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。