登录
首页 >  Golang >  Go问答

如何向 MongoDB 中的空数组推送数组对象?

来源:stackoverflow

时间:2024-03-17 20:36:32 353浏览 收藏

在 MongoDB 中,将数组对象推送到空数组时,需要指定数组索引和使用 "$each" 查询非结构化数组。通过将数组索引指定为 "$",并使用 "$each",可以将数组对象添加到指定的数组中,而不会覆盖现有元素。这解决了 MongoDB 中将数组对象推送到空数组时出现的错误,并确保数据按照预期更新。

问题内容

我正在尝试使用go来学习mongodb。 我尝试将数组推送到 mongodb 的空数组。

首先,我创建了一个这样的集合。

{
    "_id" : objectid("60c6c2d7b64d7f9d461d2bd5"),
    "title" : "test title",
    "description" : "this is test vote title",
    "candidates" : [ 
        {
            "name" : "test name",
            "score" : 0,
            "voter" : []
        }
    ]
}

这是我用于数据库的类型

type vote struct {
    title       string
    description string
    candidates  []candidate
}

type candidate struct {
    name  string
    score int
    voter []supporter
}

type supporter struct {
    uuid string
    name string
}

而且,我想要做的是将数组对象推送到空数组“voter”。 我想将这个对象推送到数据库。

[]vote.supporter{{uuid: uuid.newstring(), name: "test user a"}, {uuid: uuid.newstring(), name: "test user b"}}

然后,我使用这个命令推送了这个数组对象。

vote.votetosubject(collection, "test title", "test name", []vote.supporter{{uuid: uuid.newstring(), name: "test user a"}, {uuid: uuid.newstring(), name: "test user b"}})
func votetosubject(collection *mongo.collection, title string, name string, voter []supporter) {
    // filter := bson.d{{"title", title}, {"candidates", bson.d{{"name", name}}}}
    filter := bson.d{{"$and", []interface{}{bson.d{{"title", title}}, bson.d{{"candidates.name", name}}}}}
    update := bson.d{{"$set", bson.d{{"candidates.votes", voter}}}}
    updateresult, err := collection.updateone(context.todo(), filter, update)
    if err != nil {
        log.fatal(err)
    }

    fmt.printf("matched %v documents and updated %v documents.\n", updateresult.matchedcount, updateresult.modifiedcount)
}

我期望的是,数组对象被添加到votes空数组中(而不是替换)。

{
    "_id" : objectid("60c6c2d7b64d7f9d461d2bd5"),
    "title" : "test title",
    "description" : "this is test vote title",
    "candidates" : [ 
        {
            "name" : "test name",
            "score" : 0,
            "voter" : [
                {
                    "uuid" : *uuid1*
                    "name" : *name1*
            },  {
                    "uuid" : *uuid2*
                    "name" : *name2*
            }, 
            ]
        }
    ]
}

但是该命令返回一个错误...就像这样。

ekfkal79@DARAMI-PC MINGW64 ~/go/src/github.com/ekfkal79/go-mongo-db (main)
$ go run main.go
Connected to MongoDB!
2021/06/14 11:45:52 multiple write errors: [{write errors: [{Cannot create field 'votes' in element {candidates: [ { name: "Test Name", score: 0, voter: [] } ]}}]}, {}]
exit status 1

我不知道如何解决这个问题...我阅读了 mongodb 的文档,但没有帮助... 我需要你的帮助...

抱歉我的英语水平很差...


正确答案


是的,我解决了我的问题!

问题是,我没有指定数组的索引!!

func votetosubject(collection *mongo.collection, title string, name string, voter []supporter) {
    // filter := bson.d{{"title", title}, {"candidates", bson.d{{"name", name}}}}
    filter := bson.d{{"$and", []interface{}{bson.d{{"title", title}}, bson.d{{"candidates.name", name}}}}}
    update := bson.d{{"$addtoset", bson.d{{"candidates.$.voter", bson.d{{"$each", voter}}}}}}
    updateresult, err := collection.updateone(context.todo(), filter, update)
    if err != nil {
        log.fatal(err)
    }

    fmt.printf("matched %v documents and updated %v documents.\n", updateresult.matchedcount, updateresult.modifiedcount)
}

在变量“update”中,我将数组索引指定为“$”。然后使用“$each”查询非结构化数组“voter”!

{
    "_id" : ObjectId("60c6c2d7b64d7f9d461d2bd5"),
    "title" : "Test Title",
    "description" : "This is test vote title",
    "candidates" : [ 
        {
            "name" : "Test Name",
            "score" : 0,
            "voter" : [ 
                {
                    "uuid" : "92b5eff2-b4de-4b48-96d8-9ea41a74c22b",
                    "name" : "Test User A"
                }, 
                {
                    "uuid" : "f50037ec-d898-4b6e-a836-7cc44e306493",
                    "name" : "Test User B"
                }
            ]
        }
    ]
}

一切正常!!

谢谢大家!

以上就是《如何向 MongoDB 中的空数组推送数组对象?》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>