![](/img/trans.png)
[英]Django: Add new foreign key to existing model with default value as another foreign key from the same model
[英]Django Apply Model Foreign Key Default Value to Existing Record
非常感谢您抽出宝贵的时间。
以前,我发布了这个问题, 如何为用户获取未读帖子 。
问题是:当另一位用户已经阅读了这篇文章时,我无法过滤掉一位用户没有阅读过的文章。
我弄清楚了为什么我不能做到这一点-因为尽管我将每篇文章的阅读默认设置都设置为False-尽管我没有将Django写入数据库的数据,但是却没有记录。
然后,我在Admin中手动将一篇文章设置为未读给用户,因为一切都正常了,因为现在数据库中有一条记录表明该用户尚未阅读该文章。
现在的问题是:
如何为数据库中所有现有用户为我现有的每篇文章设置“未读”?
除非新用户实际阅读文章,否则如何使每个新用户都无法阅读文章?
为了方便起见,我将代码复制到此处。
我的模特:
class Posts(models.Model):
title = models.CharField(max_length=255)
content_url = models.URLField(unique=True)
content = models.CharField(max_length=255)
post_date = models.DateField(default="2999-12-12")
另一个
class readstatus(models.Model):
reading_status = models.BooleanField(default=False)
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
article = models.ForeignKey(Posts, on_delete=models.CASCADE)
created = models.DateTimeField(auto_now_add=True)
我的观点:
class DailyReading(ListView):
template_name = 'reading.html'
context_object_name = "data"
paginate_by = 20
def get_queryset(self):
if self.kwargs['status'] == "read":
queryset = piaoyou.objects.filter(readstatus__reading_status=True,readstatus__user=self.request.user)
return queryset
else:
queryset= Posts.objects.filter(readstatus__reading_status=False,readstatus__user=self.request.user)
return queryset
我的模板:
{% for info in data %}
<quoteblock>
<ul>
<li><a href="{{ info.get_absolute_url }}">{{ info.title }}
<footnote></footnote>
</a>{{ info.post_date }}</li>
<footnote>{{ info.get_abstract_content }}</footnote>
</ul>
</quoteblock>
{% endfor %}
天哪,我只是想出了怎么做。
对于请求用户已阅读的文章,我们只需传递queryset = Post.objects.filter(readstatus__reading_status = True,readstatus__user = self.request.user)
对于请求用户尚未阅读的文章,我们可以将Posts.objects.all()传递到模板中。
然后在模板中:
我们需要{%if instance.readstatus_set.all%}这一行来使工作正常。 假设没有有关此发出请求的用户是否已阅读文章的数据,该实例不应具有readstatus_set.all,这意味着该用户尚未阅读该文章。 一旦检查了这个if条件,我们就可以执行检查循环中的其他条件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.