58

我可以在 mongodb 查询中使用 OR 和 AND 的组合吗?

下面的代码不能按预期工作

db.things.find({
           $and:[
                {$or:[
                     {"first_name" : "john"}, 
                     {"last_name" : "john"}
                ]},
                {"phone": "12345678"}
            ]});

数据库内容:

> db.things.find();
{ "_id" : ObjectId("4fe8734ac27bc8be56947d60"), "first_name" : "john", "last_name" : "hersh", "phone" : "2222" }
{ "_id" : ObjectId("4fe8736dc27bc8be56947d61"), "first_name" : "john", "last_name" : "hersh", "phone" : "12345678" }
{ "_id" : ObjectId("4fe8737ec27bc8be56947d62"), "first_name" : "elton", "last_name" : "john", "phone" : "12345678" }
{ "_id" : ObjectId("4fe8738ac27bc8be56947d63"), "first_name" : "eltonush", "last_name" : "john", "phone" : "5555" }

查询上述查询时 - 我什么也没得到!

> db.things.find({$and:[{$or:[{"first_name" : "john"}, {"last_name" : "john"}]},{"phone": "12345678"}]});
>

我正在使用 mongo 1.8.3

4

4 回答 4

55
 db.things.find( {
      $and : [
               { 
                 $or : [ 
                         {"first_name" : "john"},
                         {"last_name" : "john"}
                       ]
               },
               { 
                 "Phone":"12345678"
               }
             ]
    } )

AND采用 2 个表达式OR,电话的数组。
OR采用 2 个表达式 first_name , last_name 的数组。

  • 或者

  • 电话号码。

注意:如果这不起作用,请升级到最新版本的 MongoDB。

于 2017-12-28T02:43:56.060 回答
37

使用隐式 AND 操作更短:

db.things.find({
    $or : [ 
        {"first_name": "john"},
        {"last_name": "john"}
    ],
    "phone": "12345678"         
})
于 2018-12-06T09:35:03.047 回答
20

这可以通过以下方式实现(mongodb 3.4)

这是一个很好的例子

https://docs.mongodb.com/manual/reference/operator/query/and/#and-queries-with-multiple-expressions-specifying-the-same-operator

        db.getCollection('tbl_menu_items').find({
        $和:[
            { $or : [ { price : 0.99 }, { price : 1.99 } ] },
            { $or : [ { sale : true }, { 数量 : { $lt : 20 } } ] }
        ]
    })

此查询将选择所有文档,其中:

price 字段值等于 0.99 或 1.99,sale 字段值等于 true 或 qty 字段值小于 20。

这是带有 $or 查询的 $and 条件的示例,例如匹配任何条件

考虑以下查询...


        db.getCollection('tbl_menu_items').find(

        {'$或':
           [ {'$和':
                [{位置:{'$in':[ObjectId(“588054c63879f2e767a1d553”)]}},
                  { is_ryward: 1 },
                  { points_reqiured_to_redeem_reward: { '$lte': 500 } } ] },
             {'$和':
                [{位置:{'$in':[ObjectId(“588054c63879f2e767a1d553”)]}},
                  { is_freebie: 1 } ] } ] }
        )



此查询将选择所有文档,其中:

位置数组在 588054c63879f2e767a1d553 和 is_ryward = 1 和 points_reqiured_to_redeem_reward < 500

或者

588054c63879f2e767a1d553 和 is_freebie 中的位置数组

于 2017-02-20T09:31:43.507 回答
13

我相信 $and 仅在 MongoDB v2.0+ 中受支持。我很惊讶控制台首先接受了这个表达式。我将尝试针对我拥有的 1.8 服务器重新创建。

另请查看10Gen 的高级查询文档以获取$and.

更新

我将您的示例数据输入到 v1.8x 和 v2.0x MongoDB 服务器中。该查询在 v2.0x 上有效,在 v1.8x 上失败。这证实了我(和 Miikka)的怀疑,即问题出在$and您的服务器版本上。

我在此处的 Web 上找到了一个(可以说)聪明的解决方法。我希望这有帮助。

-SethO

于 2012-06-25T19:48:27.233 回答