我的项目使用户能够撰写帖子,每个帖子都有一个类别,每个类别都有一个主管,所以我遇到了一个问题,我无法获取特定主管的特定类别的所有帖子。
我的模型
class PostCategory(models.Model):
name = models.CharField(max_length=150, null=True)
description = models.CharField(max_length=100, null=True)
def __str__(self):
return self.name
class UserSupervisorSpecialist(models.Model):
user = models.ForeignKey(User, related_name="user_id", on_delete=models.SET_NULL, null=True)
category = models.OneToOneField(CategoryPost, related_name="category_id", on_delete=models.SET_NULL, null=True)
def __str__(self):
return self.user.username
class Post(models.Model):
title = models.CharField(max_length=100, null=True)
content = RichTextField()
post_category = models.ManyToManyField(CategoryPost)
author = models.ForeignKey(User, on_delete=models.SET_NULL, null=True)
date_create = models.DateTimeField(auto_now_add=True, null=True)
status = models.BooleanField(default=False) #0 -> suspend
likes = models.IntegerField(default=0) #0 -> No like yet
supervisor = models.ForeignKey(UserSupervisorSpecialist, on_delete=models.SET_NULL, null=True)
def __str__(self):
return self.title
def snippet(self):
return self.content[:150]
我的观点:
def control_spanle(request):
category = UserSupervisorSpecialist.objects.filter(user=request.user)
post_filter = Post.objects.filter(supervisor=request.user.username)
return render(request, 'supervisor/controle_panel.html',{'Category':category,'post_filter':post_filter})
最佳答案
您在 Post 模型上编写了一个查询集,但未指定字段,同时将其与字符串进行比较。
您可以通过更改此行来解决此问题
post_filter = Post.objects.filter(supervisor=request.user.username)
至:
post_filter = Post.objects.filter(supervisor__name=request.user.username)
关于python - 值错误 : Field 'id' expected a number but got 'super' . [04/4/2020 18:15:11] "GET/super_user HTTP/1.1"500 132224,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61030415/