Rumah >pembangunan bahagian belakang >Golang >Kemas kini tatasusunan dalam dokumen mongdbo

Kemas kini tatasusunan dalam dokumen mongdbo

王林
王林ke hadapan
2024-02-09 14:18:19949semak imbas

更新 mongdbo 文档中的数组

editor php Yuzai akan memperkenalkan kepada anda cara mengemas kini tatasusunan dalam dokumen MongoDB dalam artikel ini. MongoDB ialah pangkalan data bukan perhubungan yang struktur dokumennya sangat fleksibel dan boleh mengandungi pelbagai jenis data, termasuk tatasusunan. Dalam pembangunan sebenar, kita sering perlu mengemas kini data yang disimpan dalam tatasusunan. Artikel ini akan menerangkan secara terperinci cara menggunakan pengendali kemas kini MongoDB untuk mengemas kini tatasusunan dalam dokumen, serta beberapa senario dan langkah berjaga-jaga penggunaan biasa. Sama ada anda baru menggunakan MongoDB atau pembangun berpengalaman, anda boleh memperoleh pengetahuan berguna dan pengalaman praktikal daripada artikel ini.

Kandungan soalan

Saya cuba mengemas kini item tatasusunan dalam dokumen mongo.

event ialah dokumen, saya dapati dengan id acara, maka saya perlu mengenal pasti objek mana dalam tatasusunan tugas yang perlu ditukar dengan mengenal pasti nama tugas.

Tahu di mana silap saya

Struktur acara

type event struct {
eventid              string       `json:"eventid" bson:"eventid"`
eventowner           string       `json:"eventowner" bson:"eventowner"`
eventtitle           string       `json:"eventtitle" bson:"eventtitle"`
eventdatetime        string       `json:"eventdatetime" bson:"eventdatetime"`
eventlocation        eventaddress `json:"eventlocation" bson:"eventlocation"`
eventtotalticket     int          `json:"eventtotalticket" bson:"eventtotalticket"`
eventavailableticket int          `json:"eventavailableticket" bson:"eventavailableticket"`
eventcoverimage      string       `json:"eventcoverimage" bson:"eventcoverimage"`
eventdescription     string       `json:"eventdescription" bson:"eventdescription"`
lat                  string       `json:"lat" bson:"lat"`
long                 string       `json:"long" bson:"long"`
task                 []task       `json:"task" bson:"task"`
}

Struktur tugas:

type task struct {
tasktitle    string  `json:"tasktitle" bson:"tasktitle"`
initalbudget float32 `json:"initialbudget" bson:"initialbudget"`
supplier     string  `json:"suppid" bson:"suppid"`
agreedprice  float32 `json:"agreedprice" bson:"agreedprice"`
iscomplete   bool    `json:"iscomplete" bson:"iscomplete"`
}

Ini yang saya nak buat

func (e *EventServiceImpl) UpdateTask(eventid *string, task *models.Task) error {

    //filter := bson.D{bson.E{Key: "eventid", Value: eventid}, bson.E{Key: "tasktitle", Value: task.TaskTitle}}
    filter := bson.M{"$and": []bson.M{{"eventid": eventid}, {"task": bson.E{Key: "tasktitle", Value: task.TaskTitle}}}}
    update := bson.D{bson.E{Key: "$set", Value: bson.D{bson.E{Key: "task", Value: bson.M{"tasktitle": task.TaskTitle, "initialbudget": task.InitalBudget, "suppid": task.Supplier, "agreedprice": task.AgreedPrice, "iscomplete": task.IsComplete}}}}}
    result, _ := e.eventcollection.UpdateOne(e.ctx, filter, update)
    if result.MatchedCount != 1 {
        return errors.New("No matched document found to update")
    }
    return nil

}

Saya terus mendapat "Tiada dokumen sepadan ditemui untuk dikemas kini"

Penyelesaian

Inilah penyelesaiannya

func (e *EventServiceImpl) UpdateTask(eventid *string, task *models.Task) error {
    filter := bson.M{"eventid": eventid, "task": bson.M{"$elemMatch": bson.M{"tasktitle": task.TaskTitle}}}
    update := bson.M{"$set": bson.M{"task.$.initialbudget": task.InitalBudget, "task.$.suppid": task.Supplier, "task.$.agreedprice": task.AgreedPrice, "task.$.iscomplete": task.IsComplete}}
    result, err := e.eventcollection.UpdateOne(e.ctx, filter, update)
    if err != nil {
        return err
    }
    if result.MatchedCount != 1 {
        return errors.New("No matched document found to update")
    }
    return nil
}

Atas ialah kandungan terperinci Kemas kini tatasusunan dalam dokumen mongdbo. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam