我有一个家庭作业模型,该模型要根据日期(date_view)进行过滤以显示家庭作业。看起来像这样-
家庭作业模型
class Homework(models.Model):
hw_id = models.CharField(unique=True, max_length=50)
homework = models.TextField()
subject = models.ForeignKey(Subject, on_delete=models.CASCADE)
class_id = models.ForeignKey(Classes, on_delete=models.CASCADE)
date_added = models.DateTimeField(auto_now_add=True)
date_updated = models.DateTimeField(auto_now=True)
date_view = models.DateTimeField(default=datetime.now())
但是当我尝试这样过滤时-
hw = Homework.objects.filter(class_id=class_id).filter(date_view__gte='homework__date_added')
我收到此错误-
['“homework__date_added” value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format.']
我认为我以错误的方式过滤了数据。但是我应该如何过滤数据?
答案 0 :(得分:1)
您可以使用F
object [Django-doc]来引用字段:
from django.db.models import F
hw = Homework.objects.filter(
class_id=class_id,
date_view__gte=F('date_added')
)