前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >InfluxDB常见问题和解答 - 如何在InfluxDB中实现嵌套子查询

InfluxDB常见问题和解答 - 如何在InfluxDB中实现嵌套子查询

原创
作者头像
hanj4096
发布于 2019-11-25 12:08:42
发布于 2019-11-25 12:08:42
4K00
代码可运行
举报
运行总次数:0
代码可运行

网友岛:

请问,influxDB到底支不支持嵌套子查询呢?

Answer:

嵌套子查询,类似以下SQL语句,从本质上讲,是嵌套函数。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT mean(max("cpu_usage")) FROM "cpu_usage_detail" GROUP BY time(1m)

大多数InfluxQL的内置函数不支持函数的嵌套,可以借助连续查询来实现类似的功能,先通过连续查询做实现子查询功能,把结果保存到新表中,然后再对新表中的结果执行查询。

例如,统计一段时间内的每分钟最大CPU利用率的均值,在InfluxDB中,可以通过以下步骤实现:

1) 创建一条连续查询

我们创建一条连续查询,用于定期统计每分钟CPU的最大利用率,并将结果保存在一张汇总表cpu_result中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE CONTINUOUS QUERY "cpu_cq" ON "cpu_db" 
BEGIN 
    SELECT max("cpu_usage") AS "max_cpu" INTO "cpu_result" FROM "cpu_usage_detail" GROUP BY time(1m) 
END

2) 对连续查询结果进行查询

我们再对表cpu_result进行查询,即可计算出一个时间段内的每分钟最大CPU利用率的均值了。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT mean("max_cpu") FROM "cpu_result" 
WHERE time >= <start_time> AND time <= <end_time>

后记:

欢迎交流讨论:

微信公众号:influxdb-dev。

InfluxDB技术交流群(QQ):663274123。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验