sql >> Database teknologi >  >> NoSQL >> MongoDB

Hvordan laver man en Atomic Update på et Embedded Document i et ListField i MongoEngine?

Du kan bruge positionsoperatoren til at opdatere det matchede indlejrede dokument.

Her er et eksempel fra testene (https://github.com/MongoEngine/mongoengine/blob/master/tests/test_queryset.py#L313)

def test_update_using_positional_operator(self):
    """Ensure that the list fields can be updated using the positional
    operator."""

    class Comment(EmbeddedDocument):
        by = StringField()
        votes = IntField()

    class BlogPost(Document):
        title = StringField()
        comments = ListField(EmbeddedDocumentField(Comment))

    BlogPost.drop_collection()

    c1 = Comment(by="joe", votes=3)
    c2 = Comment(by="jane", votes=7)

    BlogPost(title="ABC", comments=[c1, c2]).save()

    BlogPost.objects(comments__by="jane").update(inc__comments__S__votes=1)

    post = BlogPost.objects.first()
    self.assertEquals(post.comments[1].by, 'jane')
    self.assertEquals(post.comments[1].votes, 8)



  1. Apache HBase + Apache Hadoop + Xceivers

  2. Nodejs Mongo indsæt i underdokument - dynamisk feltnavn

  3. Mongo-projektionsforespørgselsresultater varierer fra test i shell vs nodejs-applikation

  4. Hvordan kører jeg Redis på Windows?