10

我无法弄清楚这个错误的含义

LEFT_SUBFIELD 仅支持 Object: stats not: 6

当我插入我的配置文件集合时,它似乎正在发生。我正在使用 mongoose.js。我们在 stats 属性中插入每个类别的帖子计数,例如

stats: {category:count, category2: count2}.

这是我的架构

var ProfileSchema = new Schema({
  uname: {
    type: String,
    required: true,
    index: true,
    unique: true
  },
  fname: String,
  lname: String,
  stats: {
    type:{},
    "default":{},
    required:true
  },
  created: {
    type:Date,
    required:true,
    "default":Date.now
  }
});

我认为当我更新 stats 对象 $inc 计数时可能会发生这种情况,以便 stats 可以得出类似此更新的结果

db.status.update({_id:xyz}, {$inc: { stats.foo : 1, stats.bar:1}})

这是我的猫鼬代码

      var tags = ["comedy", "action", "drama"];

      //also adding the postId to the posts collection of profile
      var updateCommand = {$push: {posts: post._id}};

      var stats = {};
      for (var i = tags.length - 1; i >= 0; i--){
        stats["stats." + tags[i].toString()] = 1;
      };
      updateCommand.$inc = stats;

      Profile.update(
        {uname: uname}, 
        updateCommand,
        {safe:true, upsert:true},
        callback
      );
4

3 回答 3

24

如果您尝试更新非对象的子文档,也会发生这种情况。

> db.test.insert({_id: 10240292, object: 'some string'})
> db.test.update({_id: 10240292}, {$set: {'object.subkey': 'some string'}})
LEFT_SUBFIELD only supports Object: object not: 2

也许这不是你的情况,但它可以帮助那些用谷歌搜索这个错误的人。

于 2012-10-14T12:58:03.650 回答
1

你可能会遇到这个:

https://jira.mongodb.org/browse/SERVER-2651

或者

https://jira.mongodb.org/browse/SERVER-5227

两者都已在 2.1 dev 分支中修复,但尚未(尚未)向后移植到 2.0

这里有一个关于类似问题的不错的讨论:

https://groups.google.com/forum/?fromgroups#!topic/mongodb-user/VhjhcyEdbNQ

基本上它归结为这样一个事实,即您可能会传递一个空键作为需要避免的更新的一部分。

于 2012-04-20T10:59:27.600 回答
0
db.collection('fs.files').update({_id: Object_id}, {$set: {'metadata': {"foo" : "bar"}}}
于 2015-06-05T00:25:52.660 回答