MongoDB .find有多个$或语句,语法错误'意外令牌''?

时间:2014-08-13 15:40:01

标签: mongodb mongoose

用户可以发送或接收消息,并且无论如何都应该能够存档他/她的消息。

因此,此.find应返回userA位于to.usernamefrom.usernameview.archive:true位置的所有文档。从那里开始,第二个$或者应该过滤第一个$的结果,或者只包含匹配的文档,其中的邮件是value.1:truevalue.2:truevalue.3:true

但是,现在,在第一个$或

上有关闭的SyntaxError: Unexpected token ]
Models.Messages.find(
   { 
        "$or" : [
            {
                "to": { 
                      "$elemMatch": {
                          "username": 'userA',
                          "view.archive": true,
                          "view.bin": true
                      }
                }
            },
            {
                "from" : {
                    "$elemMatch" : {
                      "username" : 'userA',
                      "view.archive": true,
                      "view.bin": true
                    }
                }
            }
        ],
      "$or": [
               { 'value.1': true },
               { 'value.2': true },
               { 'value.3': true },
               { 'value.4': false } 
             ]
   }
).sort([['updated','descending']]).exec(function (err, messages) {

应为userA找到这两条消息:

{
    "_id" : ObjectId("53e83867f316ea7f22fd3b2b"),
    "updated" : ISODate("2014-08-11T03:29:06.000Z"),
    "message" : "message1",
    "value" : [
                "1" : true,
                "2" : false,
                "3" : false,
                "4" : false
            ]
    "to" : [ 
        {
            "user" : ObjectId("53e835bd76e0d04318d8cc4e"),
            "username" : "userA",
            "_id" : ObjectId("53e83867f316ea7f22fd3b2c"),
            "view" : {
                "inbox" : false,
                "outbox" : false,
                "archive" : true,
                "bin" : false
            }
        }
    ],
    "from" : [ 
        {
            "user" : ObjectId("53e8360276e0d04318d8cc55"),
            "username" : "userB",
            "_id" : ObjectId("53e83867f316ea7f22fd3b2d"),
            "view" : {
                "inbox" : false,
                "outbox" : true,
                "archive" : false,
                "bin" : false
            }
        }
    ],
    "__v" : 5
}
{
    "_id" : ObjectId("53e83867f316ea7f22fd3b2b"),
    "updated" : ISODate("2014-08-11T03:29:06.000Z"),
    "message" : "message2",
    "value" : [
                "1" : false,
                "2" : true,
                "3" : false,
                "4" : false
            ]
    "to" : [ 
        {
            "user" : ObjectId("53e8360276e0d04318d8cc55"),
            "username" : "userB",
            "_id" : ObjectId("53e83867f316ea7f22fd3b2c"),
            "view" : {
                "inbox" : true,
                "outbox" : false,
                "archive" : false,
                "bin" : false
            }
        }
    ],
    "from" : [ 
        {
            "user" : ObjectId("53e835bd76e0d04318d8cc4e"),
            "username" : "userA",
            "_id" : ObjectId("53e83867f316ea7f22fd3b2d"),
            "view" : {
                "inbox" : false,
                "outbox" : true,
                "archive" : true,
                "bin" : false
            }
        }
    ],
    "__v" : 5
}

1 个答案:

答案 0 :(得分:0)

感谢@JohnnyHK对this question的回答,因为它也适用于此。

在MongoDB中暗示了$和隐含的.find,但是当合并$或过滤器时,它似乎是必要的,正如@soulcheck所指出的那样。

Models.Messages.find(
   { 
          $and: [{
            "$or" : [
                {
                    "to": { 
                          "$elemMatch": {
                              "username": 'userA',
                              "view.archive": true,
                              "view.bin": false
                          }
                    }
                },
                {
                    "from" : {
                        "$elemMatch" : {
                            "username" : 'userA',
                          "view.archive": true,
                          "view.bin": false
                        }
                    }
                }
            ]}, {
            "$or": [
                     { 'value.1': true },
                     { 'value.2': true },
                     { 'value.3': true },
                     { 'value.4': false } 
                   ]
            }
          ]
   }
).sort([['updated','descending']]).exec(function (err, messages) {