db.companies.aggregate([$match:{founded_year:{$ne:null,$gte:1990},founded_month:{$ne:null}}},{$group:{_id:{fy:”founded_year”,fm:”$founded_month”},nuumC:{$sum:1}}},{$sort:{numC:-1}}]);
时间: 2023-11-01 16:10:17 浏览: 194
houzi.rar_site:www.pudn.com
这是一个 MongoDB 的聚合查询,意思是找出创建年份在1990年及以后且创建月份不为空的公司,然后按照创建年份和月份分组计算公司数量,最后按照公司数量从大到小排序。但是这个查询有一些语法错误,正确的写法应该是:
```
db.companies.aggregate([
{$match: {founded_year: {$ne: null, $gte: 1990}, founded_month: {$ne: null}}},
{$group: {_id: {fy: "$founded_year", fm: "$founded_month"}, numC: {$sum: 1}}},
{$sort: {numC: -1}}
]);
```
注意到 `$match`、`$group` 和 `$sort` 都是聚合管道操作符,它们会依次处理输入的文档流,并输出一个新的文档流。`$match` 用于筛选符合条件的文档,`$group` 用于按照指定字段分组并进行计算,`$sort` 用于对结果进行排序。其中 `$sum` 用于计算指定字段的总和。
阅读全文