Mettre à jour le tableau dans le document mongdbo
Feb 09, 2024 pm 02:18 PML'éditeur php Yuzai vous présentera comment mettre à jour les tableaux dans les documents MongoDB dans cet article. MongoDB est une base de données non relationnelle dont la structure documentaire est très flexible et peut contenir différents types de données, notamment des tableaux. Dans le développement réel, nous devons souvent mettre à jour les données stockées dans le tableau. Cet article expliquera en détail comment utiliser l'opérateur de mise à jour de MongoDB pour mettre à jour le tableau dans le document, ainsi que certains scénarios d'utilisation courants et précautions. Que vous soyez nouveau sur MongoDB ou développeur expérimenté, vous pouvez acquérir des connaissances utiles et une expérience pratique grâce à cet article.
Contenu de la question
J'essaie de mettre à jour un élément de tableau dans un document mongo.
event est le document, je le trouve par l'identifiant de l'événement, puis je dois identifier quel objet du tableau des tâches doit être modifié en identifiant le nom de la tâche.
Sachez où je me suis trompé
Structure de l'événement
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"` }
Structure des tâches :
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"` }
C'est ce que je veux faire
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 }
Je reçois constamment "Aucun document correspondant trouvé à mettre à jour"
Solution
C'est la solution
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 }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?

Comment écrire des objets et des talons simulés pour les tests en Go?

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?

Comment rédigez-vous des tests unitaires en Go?

Comment écrire des fichiers dans GO Language de manière pratique?
