u
ubomjҚыр. 24, 2019, 10:08 Т.Ж.

При создании/обновлении Article обновлять и Section up_date

Всем привет! Может кто-то уже сталкивался с подобным....
Надо (пока для меня непонятно как) при создании/обновлении Article обновлять и Section up_date
Возможно ли такое сделать?

class Section(models.Model):
    class Meta:
        verbose_name = 'тратата'
        verbose_name_plural = 'трататы'

    title = models.CharField('Название', max_length=150)
    slug = models.SlugField('URL', null=True, blank=True, unique=True)
    description = models.TextField('Описание категории', null=True, blank=True)
    image = models.ImageField ('картинка', upload_to='images/')
    pub_date = models.DateTimeField(auto_now_add=True)
    up_date = models.DateTimeField(auto_now=True)

    def __str__(self):
        return self.title
class Article(models.Model):
    class Meta():
        verbose_name = 'апвапва'
        verbose_name_plural = 'вапвв'

    title = models.CharField('Название', max_length=150)
    slug = models.SlugField('URL', null=True, blank=True, unique=True)
    meta_description = models.CharField('meta_description', max_length=150, null=True, blank=True)
    section = models.ForeignKey('Section', on_delete=models.CASCADE)
    image = models.ImageField ('Изображение', upload_to='img/')
    dl = models.FileField ('Архив', upload_to='dl/')
    content_field_1 = models.CharField('', null=True, blank=True, max_length=150)
    pub_date = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)

# Тут проблемка (как я пытался это сделать)
    def save(self, *args, **kwargs):
        self.section.up_date = self.updated
        super(Section, self).save(*args, **kwargs)


    def __str__(self):
        return self.title
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

2
Илья Чичак
  • Қыр. 24, 2019, 10:32 Т.Ж.
  • (өңделген)
  • Жауап шешім ретінде белгіленді.

смотрите, у вас не получается, поскольку в методе save вы изменяете аттрибут up_date, но не сохраняете его.
Вы можете исправить это так:

    def save(self, *args, **kwargs):
        self.section.up_date = self.updated
        self.section.save()
        super(Section, self).save(*args, **kwargs)

еще вариант:
поскольку у вас есть параметр "auto_now=True", можно просто вызывать метод "save()" модели "Section":

    def save(self, *args, **kwargs):
        self.section.save()
        super(Section, self).save(*args, **kwargs)

с этим параметром в момент сохранения автоматически подставляется время сохранения

и последний вариант:
если вы хотите только показывать это значение, но не планируете по нему сортировать, можно сделать метод-свойство:

class Section(models.Model):
    ...

    @property
    def up_date(self):
        return self.articles_set.order_by('update').first().update

тогда при обращении к "Section.up_date" будет возвращаться значение update самой свежей "Article".
а если всетаки надо сортировать по этому полю - можно это сделать так:

Section.objects.all().order_by('article_set__update')
    u
    • Қыр. 24, 2019, 10:50 Т.Ж.

    Огромное спасибо!
    За несколько вариантов отдельное спасибище :)

      Пікірлер

      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
      Кіріңіз немесе Тіркеліңіз
      Г

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:66ұпай,
      • Бағалау ұпайлары-1
      t

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:33ұпай,
      • Бағалау ұпайлары-10
      t

      Qt - Тест 001. Сигналы и слоты

      • Нәтиже:52ұпай,
      • Бағалау ұпайлары-4
      Соңғы пікірлер
      G
      GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
      Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
      d
      dblas5Шілде 5, 2024, 11:02 Т.Ж.
      QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      k
      kmssrАқп. 8, 2024, 6:43 Т.Қ.
      Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
      АК
      Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
      Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
      Енді форумда талқылаңыз
      Evgenii Legotckoi
      Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
      F
      FynjyШілде 22, 2024, 4:15 Т.Ж.
      при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
      BlinCT
      BlinCTМаусым 25, 2024, 1 Т.Ж.
      Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
      BlinCT
      BlinCTМамыр 5, 2024, 5:46 Т.Ж.
      Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
      Evgenii Legotckoi
      Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

      Бізді әлеуметтік желілерде бақылаңыз