6

这是我正在尝试做的一个例子,因为我无法解释我的意思。

我在 mongo CLI 中执行此操作:db.posts.insert({name: "Hello, world!, body: "Here's my first blog post. Happy reading!", comments: []})。我想要做的是更新该条目以向comments字典添加评论。

我将如何使用db.posts.update()

4

2 回答 2

15

OP的问题和示例不匹配。他实际上想在文档内的数组中插入一个字段,这意味着

db.posts.update({name: "Hello, world!" }, { $push: {comments: "First comment!"}});

工作得很好。

但是,如果您想向字典中添加值或子文档,则可以使用该$set命令。以这个文档为例:

{
    "_id": {
        "$oid": "538420b2862a656e9e99fc93"
    },
    "name": "Farmer John",
    "items": {
        "peaches": 5,
        "bananas": 10
    }
}

假设您希望添加"apples": 2到项目中。该命令将是

db.collection.update({"name": "Farmer John"},
                     {"$set": {"items.apples": 2}});

您的文档将如下所示:

{
    "_id": {
        "$oid": "538420b2862a656e9e99fc93"
    },
    "name": "Farmer John",
    "items": {
        "peaches": 5,
        "bananas": 10,
        "apples: 2
    }
}

请注意,这也适用于插入子文档,因此我们可以修改原始示例:

{
    "_id": {
        "$oid": "538420b2862a656e9e99fc93"
    },
    "name": "Farmer John",
    "items": {
        "peaches": {
            "yellow": 5,
            "white": 3
        }
    }
}

让我们插入 4 个青苹果和 8 个富士苹果。

db.collection.update({"name": "Farmer John"},
                     {"$set": {"items.apples": {"fuji": 8, "granny smith": 4}}});

我们的文件现在是:

{
    "_id": {
        "$oid": "538420b2862a656e9e99fc93"
    },
    "name": "Farmer John",
    "items": {
        "peaches": {
            "yellow": 5,
            "white": 3
        },
        "apples": {
            "fuji": 8,
            "granny smith": 4
        }
    }
}

最后一条评论:请注意,如果子文档或字段已经存在,那么它将被$set命令覆盖。

于 2014-06-30T16:56:28.850 回答
-3

对于像这样的对象:

{
  name: "Hello, world!",
  content: "This is my first post"
}

如果你现在跑

db.posts.update({name: "Hello, world!"}, {name: "First post"});

这就是结果:

{
  title: "First post"
}

content 属性将被删除,因为没有提供替换值。我提到这一点是因为这是一个常见的错误。

所以如果你想“添加”一个属性,你需要运行:

db.posts.update({name: "Hello, world!" }, { $push: {comments: "First comment!"}});

如果要将数据附加到数组,则使用 $push。如果它是一个普通字段,请使用 $set。

参考:http ://www.mongodb.org/display/DOCS/Updating

于 2012-07-10T11:40:32.613 回答