更新mongodb中的嵌套文档

更新mongodb中的嵌套文档,mongodb,Mongodb,假设我有这样一个数据结构: { 'name': 'test', 'anotherdoc': { 'something': 'someval', 'somenum': 1 } } 现在,假设我想做点什么。起初,我认为应该这样做: collection.update({'_id': myid}, {$set: {'anotherdoc.something': 'somenewval'}); 然而,这似乎是不正确的。它确实在里面放了一些数据,

假设我有这样一个数据结构:

{
    'name': 'test',
    'anotherdoc': {
        'something': 'someval',
        'somenum': 1
    }
}
现在,假设我想做点什么。起初,我认为应该这样做:

collection.update({'_id': myid}, {$set: {'anotherdoc.something': 'somenewval'});
然而,这似乎是不正确的。它确实在里面放了一些数据,但它的方式很奇怪。在这种情况下,结果会是这样:

[
    {
        'name': 'test',
        'anotherdoc': {
            'something': 'someval',
            'somenum': 1
        }
    },
    ['anotherdoc.something', 'someval']
]

当然,这不是我想要的。

你最好在mongodb用户的googlegroup中问这个问题。
你的问题的答案在这里

以下是我在mongo shell上的作品,所以我不确定上面发生了什么。试试这个,看看是否有效?如果是这样的话,我会说抓取最新的mongo代码,以防出现问题

x = { 'name': 'test', anotherdoc: { 'something': 'someval', somenum : 1 } }
> x
{"name" : "test" , "anotherdoc" : {"something" : "someval" , "somenum" : 1}}
> collection = db.foo;
test.foo
> collection.insert(x)
> collection.find()
{"_id" :  ObjectId( "4a61b6711591f41f0f1bc5ff")  , "name" : "test" , "anotherdoc" : {"something" : "someval" , "somenum" : 1}}
> x
{"name" : "test" , "anotherdoc" : {"something" : "someval" , "somenum" : 1}}
> x._id
> x = collection.findOne()
{"_id" :  ObjectId( "4a61b6711591f41f0f1bc5ff")  , "name" : "test" , "anotherdoc" : {"something" : "someval" , "somenum" : 1}}
> collection.update({'_id': x._id}, {$set: {'anotherdoc.something': 'somenewval'}} )
> collection.find()
{"_id" :  ObjectId( "4a61b6711591f41f0f1bc5ff")  , "name" : "test" , "anotherdoc" : {"somenum" : 1 , "something" : "somenewval"}}
> 

如上所述,MongoDB论坛的浏览速度可能更快(或者试试IRC)。

hm,说实话,我是用python而不是在解释器中进行测试的。如果它与解释器一起工作,那么问题一定出在我用python实现它的过程中。如果MongoDB论坛仍然无法正常工作,我会来这里。如果
另一个doc.something
是数组类型,我如何将另一个元素推到该类型?