189 votes

Rechargement de l'objet django depuis la base de données

Est-il possible de rafraîchir l'état d'un objet django à partir de la base de données ? Je veux dire un comportement à peu près équivalent à :

new_self = self.__class__.objects.get(pk=self.pk)
for each field of the record:
    setattr(self, field, getattr(new_self, field))

UPDATE : J'ai trouvé une guerre reopen/wontfix dans le tracker : http://code.djangoproject.com/ticket/901 . Je ne comprends toujours pas pourquoi les mainteneurs n'aiment pas cela.

320voto

Tim Fletcher Points 1271

Depuis la version 1.8 de Django, le rafraîchissement des objets est intégré. Lien vers les documents .

def test_update_result(self):
    obj = MyModel.objects.create(val=1)
    MyModel.objects.filter(pk=obj.pk).update(val=F('val') + 1)
    # At this point obj.val is still 1, but the value in the database
    # was updated to 2. The object's updated value needs to be reloaded
    # from the database.
    obj.refresh_from_db()
    self.assertEqual(obj.val, 2)

29voto

Rory Points 8667

J'ai trouvé qu'il était relativement facile de recharger l'objet depuis la base de données comme ça :

x = X.objects.get(id=x.id)

20voto

Ron Points 3535

Comme l'a souligné @Flimm, c'est une solution vraiment géniale :

foo.refresh_from_db()

Cela recharge toutes les données de la base de données dans l'objet.

17voto

Eloff Points 5224

En référence au commentaire de @grep, ne devrait-il pas être possible de faire :

# Put this on your base model (or monkey patch it onto django's Model if that's your thing)
def reload(self):
    new_self = self.__class__.objects.get(pk=self.pk)
    # You may want to clear out the old dict first or perform a selective merge
    self.__dict__.update(new_self.__dict__)

# Use it like this
bar.foo = foo
assert bar.foo.pk is None
foo.save()
foo.reload()
assert bar.foo is foo and bar.foo.pk is not None

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X