Хранить версионную историю Field в модели Django

У меня есть модель с текстовым полем, которая должна быть версионной.

class Book(models.Model):
    title = models.CharField(max_length=100)
    summary = models.TextField()

Ожидаемое поведение выглядит следующим образом:

  • Если я создаю новую книгу со сводкой, текст будет сохранен как обычно
  • Если сводка обновляется, старое состояние необходимо где-то хранить с номером версии и отметкой времени
  • Это должно быть легко возможно запросить текущую, диапазон или конкретные версии
  • Только поле summary должна быть версия, а не вся модель

Как мне это сделать?

1 ответ

Решение

Получил это сам.

Сначала создайте новую модель под названием SummaryHistory:

class SummaryHistory(models.Model):
    version = models.IntegerField(editable=False)
    book = models.ForeignKey('Book')
    text = models.TextField()

    class Meta:
        unique_together = ('version', 'book',)

    def save(self, *args, **kwargs):
        # start with version 1 and increment it for each book
        current_version = SummaryHistory.objects.filter(book=self.book).order_by('-version')[:1]
        self.version = current_version[0].version + 1 if current_version else 1
        super(SummaryHistory, self).save(*args, **kwargs)

Теперь расширьте исходную модель следующим образом:

class Book(models.Model):
    title = models.CharField(max_length=100)
    summary = models.TextField()

    def summary_history(self):
        return SummaryHistory.objects.filter(book=self).order_by('-version')

    def save(self, *args, **kwargs):
        super(Book, self).save(*args, **kwargs)
        # save summary history
        summary_history = self.summary_history()
        if not summary_history or self.summary != summary_history[0].text:
            newSummary = SummaryHistory(book=self, text=self.summary)
            newSummary.save()

Теперь при каждом обновлении книги будет создаваться новая увеличенная версия сводки для конкретной книги, если она не изменилась.

Другие вопросы по тегам