IoTDB 分段查询语句详解:GROUP BY + 时序语义

38f9c6efb847e9cdee6840b59e459c44.jpeg

GROUP BY 查询子句的时序语义展开,IoTDB 支持的分段方式总结!

存储的数据通过分析来发挥价值,当一组被存储的数据通过查询得到分析后的结果时,这些数据才真正在数据库中实现了价值闭环。

在关系型数据库中,GROUP BY 子句是 SQL 语言中用于将结果集按照一个或多个列分组的关键字。它通常与聚合函数一起使用,如 COUNT(), SUM(), AVG(), MIN(), MAX() 等,以便对每个分组的数据进行统计或计算。但由于关系型数据库中的数值没有时间顺序的概念,所以在分组时并不会考虑分组键前后。

如下图所示:基于值列的分组通常以数据是否等值为分组条件,分段方式较为固定。

26764b9f94ba794053abbbc259b57205.png

而时序场景下,比起分组键的列值组合,我们通常更加在意时间维度前后数据的联系。基于时间列分组,可能要求不同大小的滑动窗口等符合时序语义的分段方式。

aeafc21b43ad86d1d37d3eb9587421aa.png

因此 IoTDB 提供了针对基于时间列的新型分段场景,支持用户使用内置简单 SQL 语句快速便捷的对时序数据进行分段,更好的提取时序数据的相关特征,帮助用户更高效的在时序场景下发掘数据价值。

01 方法一:按时间区间分段

作为最基本的时间分段方式,IoTDB 可以支持基本的时间滑动窗口分段。可以指定聚合的时间间隔和滑动步长来定义窗口。其 SQL 主要包含三个参数:

  • [startTime, endTime): 查询的时间范围

  • interval: 单个分段窗口的大小

  • sliding step: 窗口的滑动步长

GROUP BY ([startTime, endTime), size, step)

下图展示了这三个参数的含义:

4fff6616789a5ee65b0be89666383e43.png

02 方法二:按数据差值分段

传统的分段方式可以对相同的值进行分段,在时序语义下,由于数据可以保证按时间顺序到来,我们可以将值的变化规律作为分段的依据。

在 IoTDB 的差值分段中,我们将第一条数据作为一个时间段的基准,每个分段会按照给定表达式与基准数值行进行差值运算,如果差值小于给定的阈值则加入当前时间段;如果超过给定阈值,则分为下一个时间段。

下图解释了该分段方式:

4493aea84ca7bc3d867da9b4e6b2c9e6.jpeg

其 SQL 与不同的参数含义如下:

GROUP BY VARIATION(controlExpression[,delta][,ignoreNull=true/false])
  • controlExpression:分组所参照的值,可以是数据行中的某一列或是多列的表达式

  • delta:分组所使用的阈值,默认为 0

  • ignoreNull:用于指定 controlExpression 计算结果为 null 时对数据的处理方式,ignoreNull 为 true 时,则直接跳过对应的点,否则创建新的时间段。

03 方法三:按会话间隔分段

在实际场景,即使是有序的时间列,可能也并不连续。而这些时间列之间的时间间隔便可以作为分段的依据,会话分段可以将时间间隔超过一定阈值的数据切割为不同时间段。如下所示:

4e9b8d93b697362c95139bf7b3915e3f.jpeg

GROUP BY SESSION(timeInterval)

04 方法四:按数据点数分段

在一些场景中,我们会在时序语义下基于连续的时间点数做分段,将连续的指定数量数据点分为一组。如下所示:

39d157597ed4800a61fec9a32fa13f25.jpeg

GROUP BY COUNT(controlExpression,size[,ignoreNull=true/false])

05 方法五:按符合条件的数据点数分段

对于顺序到来的数据,我们还可以指定条件表达式来对数据行进行筛选。将符合条件的连续数据点加入时间段,如下图,将数值为 True 的数据点每三个分为一段,其分段示意图和 SQL 定义如下:

681fb7e9e9d7d007090d0b4398a24da1.jpeg

GROUP BY CONDITION(predictExpression[keep >/>=/=/<=/<]threshold[,ignoreNull=true/false])
  • predictExpression:返回值为 boolean 数据类型的表达式,用于数据行的筛选

  • keep:行数满足 keep 的表达式的数据行会被加入到时间段中

  • ignoreNull:predictExpression 为 null 时数据行的处理方式,为 true 跳过该行,否则创建新的时间段

06 总结

本文为大家详细介绍了当前 IoTDB 中具备时序特色语义的分段方式,不同于关系型数据库的传统关系代数(针对无序集合的算子),上述分段方式均利用了时序数据天然有序的语义,大家可以通过这些便捷的语法实现自身业务的查询需求。除了这些分段方式之外,IoTDB 本身提供了一个通用的分段框架,欢迎感兴趣的朋友参与 IoTDB 社区,贡献多样的分段实现。

规上企业应用实例

能源电力:中核武汉国网信通产业集团华润电力大唐先一上海电气国轩清安储能太极股份绍兴安瑞思

航天航空:中航机载共性北邮一号卫星

钢铁冶炼:宝武钢铁中冶赛迪

交通运输:中车四方长安汽车城建智控德国铁路

智慧工厂与物联:PCB 龙头企业博世力士乐德国宝马京东昆仑数据怡养科技

3e8266eed7ed659a57628485d08999d5.gif

ce2a548677ced4ee530458d9741c7bf1.jpeg

9e6fd08184c33050840083e6b6eed5f2.jpeg

1697a465c28888235fb8dd57f8c7dbdb.jpeg

e4f2d677943ed82b0f748ccd7162fee2.gif

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-21 08:20:05       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 08:20:05       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 08:20:05       45 阅读
  4. Python语言-面向对象

    2024-07-21 08:20:05       55 阅读

热门阅读

  1. 河南萌新联赛2024第(一)场:河南农业大学

    2024-07-21 08:20:05       18 阅读
  2. 解决echarts在uniapp里tooltip,legend不能点击的问题

    2024-07-21 08:20:05       15 阅读
  3. web学习笔记(八十一)

    2024-07-21 08:20:05       16 阅读
  4. 这些库都有什么应用场景呢

    2024-07-21 08:20:05       16 阅读
  5. linux学习笔记整理: 关于linux:Redis数据库 2024/7/20;

    2024-07-21 08:20:05       19 阅读
  6. 安卓逆向入门(3)------Frida基础

    2024-07-21 08:20:05       17 阅读
  7. SDL常用结构体和函数接口

    2024-07-21 08:20:05       20 阅读
  8. 谷粒商城实战笔记-35-前端基础-ES6-模块化

    2024-07-21 08:20:05       17 阅读
  9. 分享一款开源免费的ftp服务工具——Pyftpsync

    2024-07-21 08:20:05       20 阅读
  10. 线程局部变量共享

    2024-07-21 08:20:05       18 阅读