Перезагрузить объект django из базы данных

Можно ли обновить состояние объекта 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 . До сих пор не понимаю, почему это не нравится сопровождающим.

115 голосов | спросил grep 7 TueEurope/Moscow2010-12-07T17:44:05+03:00Europe/Moscow12bEurope/MoscowTue, 07 Dec 2010 17:44:05 +0300 2010, 17:44:05

3 ответа


0

Начиная с 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)
ответил Tim Fletcher 14 J000000Tuesday15 2015, 19:22:50
0

Мне было довольно легко перезагрузить объект из база данных примерно так:

x = X.objects.get(id=x.id)
ответил Rory 2 FebruaryEurope/MoscowbWed, 02 Feb 2011 14:47:25 +0300000000pmWed, 02 Feb 2011 14:47:25 +030011 2011, 14:47:25
0

Что касается комментария @ 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
ответил Eloff 11 thEurope/Moscowp30Europe/Moscow09bEurope/MoscowTue, 11 Sep 2012 19:21:19 +0400 2012, 19:21:19

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132