Django 如何从用户访问组子类?

Django 如何从用户访问组子类?,django,Django,我有一个模型,当然,它是组模型的子类。如何以类似于所有用户组的方式访问用户课程(例如,request.user.courses) qs = request.user.groups.filter(course__isnull=False) for group in qs: course = group.course # or shortcuts User.get_courses = lambda self: map(lambda g: g.course, self.groups.filt

我有一个模型,当然,它是组模型的子类。如何以类似于所有用户组的方式访问用户课程(例如,
request.user.courses

qs = request.user.groups.filter(course__isnull=False)
for group in qs:
    course = group.course

# or shortcuts
User.get_courses = lambda self: map(lambda g: g.course, self.groups.filter(course__isnull=False))
# or 
User.get_courses = lambda self: Course.objects.filter(pk__in=self.groups.all())
# then
request.user.get_courses()
用户和课程之间没有直接关系。您需要获取组,然后通过在
Group
Course
之间执行模型继承生成的OneToOneField来获取课程

不确定为什么要将
组子类化。你也可以

class Course(models.Model):
    students = models.ManyToManyField(User, related_name='courses')
如果您真的想扩展
User
以拥有
User.courses
之类的
User.groups
,您可以

# Option 1
# in models.py
class UserCourse(models.Model):
     user = models.ForeignKey(User)
     course = models.ForeignKey(Course, db_column='group_id')
     class Meta:
         db_table = User.groups.through._meta.db_table

m2m = models.ManyToManyField(Course, related_name='students', through=UserCourse)
m2m.contribute_to_class(User, 'courses')

# Option 2
# simpler but has duplicated m2m table and different API
# Also a Course instance will not have corresponding
# Group instance in user.groups, which may not be correct in logic.
class UserCourse(models.Model):
     user = models.ForeignKey(User, related_name='courses')
     course = models.ForeignKey(Course)

# Option 3
# just as Option 2, but w/ M2M API
class UserCourse(models.Model):
     user = models.ForeignKey(User)
     course = models.ForeignKey(Course)
m2m = models.ManyToManyField(Course, related_name='students', through=UserCourse)
m2m.contribute_to_class(User, 'courses')