Перезагрузить объект django из базы данных - PullRequest
131 голосов
/ 07 декабря 2010

Можно ли обновить состояние объекта django из базы данных?Я имею в виду поведение, примерно эквивалентное:

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

ОБНОВЛЕНИЕ: Обнаружена война переоткрыт / wontfix в трекере: http://code.djangoproject.com/ticket/901. Все еще не понимаю, почему сопровождающие не делают 'это нравится.

Ответы [ 4 ]

209 голосов
/ 14 июля 2015

Начиная с Django 1.8 встроено обновление объектов. Ссылка на документы .

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)
26 голосов
/ 02 февраля 2011

Я обнаружил, что относительно просто перезагрузить объект из базы данных довольно просто:

x = X.objects.get(id=x.id)
16 голосов
/ 11 сентября 2012

Что касается комментария @ grep, нельзя ли это сделать:

# 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
5 голосов
/ 13 марта 2019

Как отметил @Flimm, это действительно потрясающее решение:

foo.refresh_from_db()

Это перезагружает все данные из базы данных в объект.

...