我有一个人员模型,可以分配给许多其他组模型
我试着打电话来得到这个工作人员属于哪些团体的回复,但我一直在犯错误。
有人可以帮我一把吗? 用户模型
class Staff(Model):
groups = ManyToManyField(Group,
related_name="%(class)ss",
related_query_name="%(class)s",
blank=True)
class Group(Model):
creator = ForeignKey(Employer,
on_delete=CASCADE,
related_name="%(class)ss",
related_query_name="%(class)s")
group_name = CharField(max_length=256, unique=True)
created_at = DateTimeField(auto_now_add=True)
我尝试了一些方法,例如
staff = Staff.objects.filter(pk=1)
groups = staff.group.all() # or
groups = staff.group_set.all() # or
groups = staff.group.filter()
以及其他一些我无法记住的方法,但我一直在犯错误。
提前致谢
答案 0 :(得分:5)
Django filter()返回一个QuerySet对象,该对象是结果的容器。因此,您需要在尝试访问字段之前选择特定的结果对象。
Deny from all
答案 1 :(得分:1)
django.db
class BarModel(django.db.models.Model):
name = django.db.models.CharField(256)
...
class FooModel(django.db.models.Model):
bar = django.db.models.ForeignKey('BarModel')
FooModel.bar.name # AttributeError
# the attribute of the model doesn't exist^
# *** AttributeError: 'ForwardManyToOneDescriptor' object has no attribute 'name'
FooModel.objects.all()[0].bar.name
# the attribute I meant to reference^