MongoDB:检查值是否为空或数组是否为空

Gel*_*o77 5 mongoose mongodb

我想匹配所有不包含“公司”属性或“公司”值为空或空数组的文档。

User.find({Company: {$in: [null, [] ]}}, function (err, users) {
      if (err) { throw err; }
      console.log(users.length);

}).then(function(doc) {
      console.log("finish User Company");
});
Run Code Online (Sandbox Code Playgroud)

Gré*_*EUT 10

您可以使用$or查询运算符检查每个条件:

{
  $or: [{
    // Check about no Company key
    Company: {
       $exists: false
    }
  }, {
    // Check for null
    Company: null
  }, {
    // Check for empty array
    Company: {
       $size: 0
    }
  }]
}
Run Code Online (Sandbox Code Playgroud)

  • @NBcrafts `$size` 运算符不使用索引,这就是原因。也许将最后一个条件替换为 `{"Company.0":{$exists:false}}` 会使用索引? (2认同)