首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >或者在mongodb中介于2和操作符之间

或者在mongodb中介于2和操作符之间
EN

Stack Overflow用户
提问于 2020-09-10 05:07:14
回答 1查看 154关注 0票数 3

我的集合是集合

代码语言:javascript
复制
{
    "_id" : ObjectId(""),
    "from" : 1,
    "to" : 2,
    "message" : "Hello",
}
{
    "_id" : ObjectId(""),
    "from" : 2,
    "to" : 1,
    "message" : "Hi",
}

我想执行如下的SQL查询

代码语言:javascript
复制
select * from collection where (from=1 and to=2) or (from=2 and to=1)

在mongodb中,我正在使用

代码语言:javascript
复制
db.getCollection('collection').find({
    $or:[{
      $and:[  
        {"from": 1},
        {"to":   2},
        ],
        $and:[
    {"from": 2},
    {"to": 1},
               ]
    }]
        })

但是它返回0条记录提取。

那么如何在mongodb中使用(和)或(和)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-10 05:10:57

您的语法略有偏离:

代码语言:javascript
复制
db.getCollection('collection').find({
    $or:[{ $and:[{"from": 1}, {"to": 2}] },
         { $and:[{"from": 1}, {"to": 1}] }]
})

$or数组中的每个项都需要处于闭包{...}中。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63823142

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档