我有一个称为序列的自动增量字段。我只希望它在该模型所在的主题内增加 1。通常最多约为 10。然后重置为新主题。我希望在保存覆盖方法中完成此操作:
class Video(TimeStampedModel):
title = models.CharField(max_length=200)
slug = models.SlugField(max_length=200)
description = models.CharField(max_length=500)
topic = models.ForeignKey('video.VideoTopic')
sequence = models.IntegerField(default=1)
def save(self, *args, **kwargs):
# Get last value of sequence and increment by 1
top = Video.objects.order_by('-sequence')[0]
self.sequence = top.sequence + 1
super(Video, self).save()
我的代码的问题是保存方法中的“top”只会获取具有最高编号序列的视频。
如何获取正在保存的视频主题并从中正确过滤我的查询?
最佳答案
从self.topic
获取:
top = Video.objects.filter(topic=self.topic).order_by('-sequence')[0]
您还可以使用latest()
而不是对查询集中的 [0]
进行排序和取出:
top = Video.objects.filter(topic=self.topic).latest('sequence')
在这种情况下,latest()
将获取具有特定主题的最大sequence
值的单个Video
模型实例。
关于python - 自动增加每个类别中的字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23552743/