15

我有一个类似于

{
   'user_id' : 1,
   'marks' : [10, 40]
}

我想找出至少一次得分在 20 到 30 之间的用户数量。

我尝试了以下查询

db.users.count({
   'marks' : {$gte: '20', $lt: '30'}
})

但这也包括那些分数超过 30 的人......

4

5 回答 5

33

用于$elemMatch将范围查询的两个部分约束到同一个 marks元素:

db.users.count({
    marks: {$elemMatch: {$gte: 20, $lt: 30}}
})
于 2014-08-04T02:32:20.917 回答
5

不就是这样吗:

db.scores.count( { 'marks' : { '$gt' : min_value , '$lt' : max_value } } )

在您的情况下,这将转化为:

db.scores.count( { 'marks' : { '$gt' : 20 , '$lt' : 30 } } )
于 2013-02-23T15:57:18.490 回答
2
db.scores.count(
   { marks: { $elemMatch: { $gte: 20, $lt: 30} } }
)

有关更多信息,请参阅https://docs.mongodb.com/manual/reference/operator/query/elemMatch/

于 2019-03-08T19:51:49.583 回答
1

因此,假设您在收集分数中有以下数据:

{ 'user_id' : 1, 'marks' : [ 10, 40 ] }
{ 'user_id' : 2, 'marks' : [ 5, 18 ] }
{ 'user_id' : 3, 'marks' : [ 15, 25 ] }
{ 'user_id' : 4, 'marks' : [ 22, 33 ] }

然后你会期望过滤 user_ids 3 和 4,计数为 2。

运行查询的最简单方法是:

db.scores.count({'marks':{$in: [20,21,22,23,24,25,26,27,28,29,30]}})

不过不好看...

于 2012-04-09T11:08:41.130 回答
0

用 $ 你也可以写

db.scores.count({$and: [{"price": {$lt: 30}}, {"price": {$gte: 20}}]})
于 2021-05-17T13:21:10.697 回答