网友岛:
请问,influxDB到底支不支持嵌套子查询呢?
Answer:
嵌套子查询,类似以下SQL语句,从本质上讲,是嵌套函数。
SELECT mean(max("cpu_usage")) FROM "cpu_usage_detail" GROUP BY time(1m)
大多数InfluxQL的内置函数不支持函数的嵌套,可以借助连续查询来实现类似的功能,先通过连续查询做实现子查询功能,把结果保存到新表中,然后再对新表中的结果执行查询。
例如,统计一段时间内的每分钟最大CPU利用率的均值,在InfluxDB中,可以通过以下步骤实现:
1) 创建一条连续查询
我们创建一条连续查询,用于定期统计每分钟CPU的最大利用率,并将结果保存在一张汇总表cpu_result中。
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利用率的均值了。
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 删除。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有