MongoDB聚合命令比较
admin
2023-04-12 00:02:13
0

MongoDB聚合命令比较


以下表格提供了MongoDB聚合命令属性的简要概述。



aggregate

mapReduce

group

描述

在2.2版本中新增加。

以提供聚合任务的性能和可用性的目的设计。

使用管道途径来转换对象,传递管道操作符序列,像$group、$match和$sort。

关于管道操作符的更多信息,查看《聚合管道操作符》。

实施Map-Reduce聚合以处理大数据集合。

提供分组功能。

比aggregate命令慢,比mapReduce命令功能若。

关键属性

管道操作符可以按需重复。

管道操作符对于每个输入文档不必产生一个输出文档。

也可以生成新的文档或过滤文档。

除了分组操作,可以实施复杂的聚合任务以及对逐渐增长的数据集的增量聚合。

查看《Map-Reduce示例》和《实施增量Map-Reduce》。

可以要么通过存在的字段分组,要么通过客户端keyf JavaScript函数,通过计算列分组。

查看《group》更多使用keyf函数的信息和示例。

伸缩性

限制了支持聚合管道的操作符和表达式。

然而,可以添加计算列,创建新的虚拟自对象,通过使用$project管道操作符抽取子列到结果的顶层。

查看《$project》更多信息,以及《聚合管道操作符》更多关于所有可用管道操作符的信息。

客户端map、reduce和finalize JavaScript函数提供对聚合逻辑的伸缩性。

查看《mapReduce》关于函数的具体信息和限制。

客户端reduce和finalize JavaScript函数提供对分组逻辑的伸缩性。

查看《group》关于函数的具体信息和限制。

输出结果

以各种选项返回结果(内联为一个包含结果集的文档,一个结果集的游标)或存储结果在一个集合中。

如果返回内联为一个包含结果集的文档,结果集受到BSON文档大小的限制。

在2.6版本的修改:

可以返回结果集为游标或存储结果到一个集合。

以各种选项返回结果(内联,新集合,merge,replace,reduce)。查看mapReduce关于输出选项的详细信息。

在2.2版本的修改:

对于分片map-reduce输出相比之前的版本,提供了更好的支持。

返回结果内联为一个分组条目的数组。

结果集必需符合最大BSON文档大小限制。

在2.2版本的修改:

返回的数组可以包含最多20000个元素;也就是最多20000个唯一分组。之前的版本有10000个元素的限制。

分片

支持不分片和分片输入集合。

支持不分片和分片输入集合。

不支持分片集合。

注意

 

在2.4版本之前,Javascript代码以单线程执行。

在2.4版本之前,Javascript代码以单线程执行。

更多信息

查看聚合管道和aggregate。

查看Map-Reduce和mapReduce。

查看group。

相关内容

热门资讯

定做衣柜要多少钱索菲亚定做衣柜... 回答1: 定做衣柜都是按平米计算的 索菲亚衣柜在全国有连锁店,价格也是统一的,一般一线城市跟...
九牧和箭牌的区别 最佳回答 九牧和箭牌的产品都是挺不错的,不过这两个品牌还是有一定的区别的,首先九牧和箭牌的成立时间是...
箭牌卫浴价格贵不贵求价格表 我家买了一个箭牌的马桶,我还是听我的朋友说这个牌子的马桶很好,我才去买的,花了一千三百多块钱,心痛死...
展示柜的价格是怎么定的 都是按米卖的,不同的展示柜价格肯定是不同的,到厂家了解就知道了 超市冷柜/便利店冷柜/冰柜...
辟谣!河南公布7起网络谣言典型... 4月,河南持续做好涉企业、“三农”、公共政策、社会热点、文化旅游网络谣言的发现辟除,有力打击谣言传播...
企业买AI,从“尝鲜”变成“算... 【大河财立方 记者 陈薇】以前企业采购人工智能大模型,大多只是抱着试一试的心态:这笔费用归在创新预算...
宇树发布全球首款量产版载人机甲... 【大河财立方消息】 5月12日,据宇树科技官微,宇树发布GD01载人变形机甲,定价390万元起。据介...
中国驻荷兰使馆提醒:在荷中国公... 根据世界卫生组织近日通报,一艘极地探险邮轮上出现了汉坦病毒感染病例。截至5月11日,造成至少8例感染...