KADB heap表VS AO表插入数据测试

单条插入数据准备:

test=# \d test

            Table "public.test"

 Column |         Type          | Modifiers

--------+-----------------------+-----------

 a      | integer               |

 b      | character varying(20) |

Distributed by: (a)

test=# insert into test values(generate_series(1,50000),'aaaaaaaaaa');

INSERT 0 50000

pg_dump -Fp -ftest.sql --inserts test –ttest

INSERT INTO public.test VALUES (1, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (5, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (11, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (12, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (14, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (15, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (17, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (20, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (23, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (25, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (26, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (30, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (31, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (35, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (36, 'aaaaaaaaaa');

批量加载数据准备:

copy test_heap to '/home/mppadmin/test.dat' delimiter '|';

2|aaaaaaaaaa

1|aaaaaaaaaa

3|aaaaaaaaaa

5|aaaaaaaaaa

4|aaaaaaaaaa

11|aaaaaaaaaa

6|aaaaaaaaaa

12|aaaaaaaaaa

7|aaaaaaaaaa

单条插入测试:

select current_timestamp;

INSERT INTO public.test VALUES (1, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (5, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (11, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (12, 'aaaaaaaaaa');

……

INSERT INTO public.test VALUES (49994, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (49995, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (49996, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (49997, 'aaaaaaaaaa');

INSERT INTO public.test VALUES (49999, 'aaaaaaaaaa');

select current_timestamp;

批量加载测试:

select current_timestamp;

copy test from '/home/mppadmin/test.dat' delimiter '|';

select current_timestamp;

Heap表:

test=# \d+ test_heap

                              Table "public.test_heap"

 Column |         Type          | Modifiers | Storage  | Stats target | Description

--------+-----------------------+-----------+----------+--------------+-------------

 a      | integer               |           | plain    |              |

 b      | character varying(20) |           | extended |              |

Distributed by: (a)

单条插入:

2024-07-29 22:25:19 ~ 2024-07-29 22:25:58

批量插入:

2024-07-29 22:39:58.597309+08 ~ 2024-07-29 22:39:58.81317+08

AO表:

test=# \d+ test

                                                Append-Only Columnar Table "public.test"

 Column |         Type          | Modifiers | Storage  | Stats target | Compression Type | Compression Level | Block Size | Description

--------+-----------------------+-----------+----------+--------------+------------------+-------------------+------------+-------------

 a      | integer               |           | plain    |              | zlib             | 5                 | 32768      |

 b      | character varying(20) |           | extended |              | zlib             | 5                 | 32768      |

Checksum: t

Distributed by: (a)

Options: appendonly=true, compresstype=zlib, compresslevel=5, orientation=column

单条插入:

2024-07-29 22:31:37 ~ 2024-07-29 22:33:29

批量插入:

2024-07-29 22:41:53.848749+08 ~ 2024-07-29 22:41:53.970006+08

结论:

  1. Heap表单条插入50000条用时:39s
  2. AO表单条插入50000条用时:112s
  3. Heap表批量插入50000条用时:<1s
  4. AO表批量插入50000条用时:<1s

插入效率:批量 < heap表单条插入 < AO表单条插入

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/51750.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day 02

作业&#xff1a; 1> 写一个日志文件&#xff0c;将程序启动后&#xff0c;每一秒的时间写入到文件中 1、2024- 7-29 10:31:19 2、2024- 7-29 10:31:20 3、2024- 7-29 10:31:21 ctrlc:停止程序 ./a.out 4、2024- 7-29 10:35:06 5、2024- 7-29 10:35:07 6、2024- 7-29 10:3…

轻松入门Linux—CentOS,直接拿捏 —/— <2>

一 、权限问题详细讲解 读写的权限可以分别写成 r, w, x 总共有九个权限&#xff0c;可以分组三大组分别是&#xff1a; user&#xff1a;当前文件所属用户的权限 group&#xff1a;与当前文件所属用户同一组的用户权限 others&#xff1a;其他用户的权限 故使用 u, g, o 来代表…

从装机到冯·诺依曼架构,揭秘计算机的硬件组成

在当今数字化的时代&#xff0c;计算机已经成为我们生活和工作中不可或缺的一部分。从日常办公到科学计算&#xff0c;从畅玩游戏到无人驾驶&#xff0c;计算机简直无所不能。而这一切的背后&#xff0c;离不开其精密而复杂的硬件组成。今天&#xff0c;我们将一起探索计算机的…

Java中的异常总结

异常的基本概念 异常&#xff08;Exception&#xff09;&#xff1a;表示程序在执行过程中出现的错误或异常情况。异常通常表示程序的非正常状态&#xff0c;需要处理以防止程序崩溃。错误&#xff08;Error&#xff09;&#xff1a;表示虚拟机出现的严重问题&#xff0c;通常…

Selenium Java中的isDisplayed()方法

isDisplayed&#xff08;&#xff09;方法用于确定元素是否可见。本文将详细讨论 的WebElement接口isDisplayed&#xff08;&#xff09;方法。 方法声明- boolean isDisplayed&#xff08;&#xff09;它能做什么&#xff1f;此方法用于判断元素是否显示。这个方法节省了我们…

ora-01438

ORA-01438是Oracle数据库中的一个常见错误&#xff0c;它表示在尝试插入或更新数据库表时&#xff0c;某个列的值超出了该列定义所允许的精度范围。这通常发生在处理数值类型数据时&#xff0c;如NUMBER类型&#xff0c;其中精度指的是数值的总位数&#xff08;包括整数部分和小…

带有扰动观测器的MPC电机控制

模型预测控制(Model Predictive Contro1, MPC)是一种先进的控制策略&#xff0c;虽然具有鲁棒性、建模简单、处理多变量系统、显示约束、预测未来行为和优化性能的能力等优势。它的不足在于预测控制行为的计算需要繁琐的计算量&#xff0c;以及抗干扰能力较弱。这里提出基于扰动…

HDFS原理

HDFS&#xff08;Hadoop Distributed File System&#xff09; HDFS——hadoop的分布式文件存储系统 HDFS原理19:49

day24——homework

1> 写一个日志文件&#xff0c;将程序启动后&#xff0c;每一秒的时间写入到文件中 1、2024- 7-29 10:31:19 2、2024- 7-29 10:31:20 3、2024- 7-29 10:31:21 ctrlc:停止程序 ./a.out 4、2024- 7-29 10:35:06 5、2024- 7-29 10:35:07 6、2024- 7-29 10:35:08 #include <…

视创云展:重塑线上会议体验,六大核心引领数字空间新纪元

视创云展以其革命性的“数字活动”解决方案为核心&#xff0c;精心构建了一个超越想象的未来数字世界。通过整合六大前沿技术模块&#xff0c;它不仅为参会者打造了一个身临其境的线上会议环境&#xff0c;更让每一位参与者都能跨越物理界限&#xff0c;深刻感受会议的每一个瞬…

前端八股速通(持续更新中...)

1、深拷贝和浅拷贝的区别 浅拷贝&#xff1a;浅拷贝是拷贝一层&#xff0c;引用类型共享地址。 如果属性是基本类型&#xff0c;拷贝的就是基本类型的值。 如果属性是引用类型&#xff0c;拷贝的就是内存地址。 意思是&#xff0c;当进行浅拷贝时&#xff0c;对于对象的每一…

PointCLIP: Point Cloud Understanding by CLIP

Abstract 近年来&#xff0c;基于对比视觉语言预训练(CLIP)的零镜头和少镜头学习在二维视觉识别中表现出了令人鼓舞的效果&#xff0c;该方法在开放词汇设置下学习图像与相应文本的匹配。然而&#xff0c;通过大规模二维图像-文本对预训练的CLIP是否可以推广到三维识别&#x…

关于#define的使用方法总结

文章目录 #define 预处理指令一、#define宏定义二、查看预处理文件三、#define 的使用方法四、C语言宏中“#”和“##”的用法五、常见的宏定义总结六、常考题目 #define 预处理指令 #define 是 C 和 C 编程语言中的预处理指令&#xff0c;用于定义宏&#xff08;macro&#xf…

斯坦福UE4 + C++课学习记录 13:UMG-血量条

文章目录 一、创建血量属性二、应用血量更改三、血量UI 一、创建血量属性 Unreal Motion Graphics (UMG)是 UE中用于创建用户界面 (UI) 的工具。它可以实现如下复杂功能&#xff1a; &#xff08;1&#xff09;动画&#xff1a;UMG 支持为控件添加动画。可以在 Widget Bluepri…

centos7已停用改用Rocky Linux9配置IPV4并安装docker

弃用Centos7&#xff0c;改用Rocky Linux9。 修改IP的方式有不同&#xff0c;不再是修改/etc/sysconfig/network-scripts/之下的脚本&#xff0c;系统也没有名叫network的服务。 系统通过NetworkManger和网络connetions来管理网卡和IP。 实际操作 Rocky Linux通过“系统连接”管…

扩散模型系列0 DDPM:Denoising Diffusion Probabilistic Models

前言&#xff1a; 从7月12号开始 学习了一些扩散模型的论文&#xff0c;越看越上瘾&#xff0c;对未知的渴求激励着我不断地读论文整理、学习、分析、理解 以前发的博客仅仅是对论文的翻译&#xff0c;现在觉得仅仅翻译是不够的&#xff0c;读了一篇论文以后&#xff0c;要形成…

智慧出行新纪元:Vatee万腾平台引领未来交通蓝图

在科技日新月异的今天&#xff0c;智慧出行已成为连接城市脉动、重塑生活方式的关键词。Vatee万腾平台&#xff0c;作为智慧交通领域的佼佼者&#xff0c;正以前瞻性的视角和创新的技术&#xff0c;为我们描绘出一幅未来交通的宏伟蓝图&#xff0c;让每一次出行都成为一次前所未…

扩散模型系列ControlNet: Adding Conditional Control to Text-to-Image Diffusion Models

向文本到图像扩散模型添加条件控制 摘要解读&#xff1a; 我对摘要英文的理解&#xff1a; 我们提出了一个神经网络架构ControlNet&#xff0c;可以向大规模的预训练好的文本到图像的扩散模型中添加空间条件控制。ControlNet锁住了准备生产的大规模扩散模型&#xff0c;并且重…

TCP为什么需要四次挥手?

tcp为什么需要四次挥手&#xff1f; 答案有两个&#xff1a; 1.将发送fin包的权限交给被动断开发的应用层去处理&#xff0c;也就是让程序员处理 2.接第一个答案&#xff0c;应用层有了发送fin的权限&#xff0c;可以在发送fin前继续向对端发送消息 为了搞清楚这个问题&…

生鲜云订单零售系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;商品分类管理&#xff0c;商品信息管理&#xff0c;订单评价管理&#xff0c;订单管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&#xff0c;商品信息&#x…