sql - CrateDB 聚合所有数组元素

标签 sql cratedb

我正在努力汇总(求和)所有返回的数组值。
目标列包含包含对象数组的对象。 例如

Object
- person: "bob"
- children: 
  - zaphod
    - age: 42 
  - ford
    - age: 42

在上面的例子中,我尝试像这样对年龄进行聚合,但没有成功:

SELECT SUM(people['children']['age'])
FROM mydatabase
WHERE people IS NOT null
LIMIT 100;

我看到的错误是“UnsupportedFeatureException”。
如果不支持此功能,我可以接受。但是,我很好奇我是否只是以错误的方式进行此操作。可以这样做吗?还是我可以通过下游流程更好地管理数据?

最佳答案

CrateDB 4.6 版(2021 年 7 月 13 日发布)包含一个新的标量函数 array_sum可以这样做:

SELECT ARRAY_SUM(people['children']['age'])
FROM mydatabase
WHERE people IS NOT null
LIMIT 100;

关于sql - CrateDB 聚合所有数组元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68536757/

相关文章:

mysql - 如何将此 REPLACE INTO 语句转换为 MySQL 中的等效 UPDATE 语句?

python - 如何在 CrateDB 中使用 python 执行批量插入?

postgresql - 如何配置 PostgreSQL ODBC 驱动程序

java - 搜索/插入查询 jdbc 中的反斜杠 (\) 和引号 (')

apache-kafka - 如何从 Kafka 加载数据到 CrateDB?

java - 使用 uCanAccess 驱动程序将字符串发送到 MS Access DB 时出现无效的字符值转换错误

MySQL View 、子查询和左连接的组合产生了奇怪的结果

SQL:一对多,仅选择一个

javascript - jQuery 拖放表行排序不起作用

java - Crate 连接查询花费太多时间