我试图建立一个电子学习平台如何查询多对多的关系?
我有用户(Utilisateur)谁可以采取几个课程,每门课程有几个模块和模块可以在几门课程
用户可以是学生或老师或管理员,学生被“管理”,由教师或几个和教师也可以由教师管理(如果他是一个研究员),教师由管理员
管理我不熟悉的概念MANY_TO_MANY,请大家指正
这是我的Django模型:
class Utilisateur(models.Model):
user = models.OneToOneField(User)
role = models.CharField(choices=ROLES,blank=False,max_length=50)
managed_by = models.ManyToManyField('self',
related_name='managers',
symmetrical=False,
blank=True)
course = models.ManyToManyField('Course') #can I do it? (question 2)
module = models.ManyToManyField('Module', through='UtilisateurModule')
class Course(models.Model):
titre = models.CharField(blank=False,max_length=100)
class Module(models.Model):
titre = models.CharField(blank=False,max_length=100)
course = models.ManyToManyField(Course, through='ModuleCourse')
class ModuleCourse (models.Model):
module = models.ForeignKey(Module)
course = models.ForeignKey(Course)
order = models.IntegerField(blank=False)
class UtilisateurModule (models.Model):
user = models.ForeignKey(Utilisateur)
module = models.ForeignKey(Module)
score = models.IntegerField(blank=False)
我的问题:
。如何通过模块来获取用户的分数和过程显示出来,这样的:
-Course A
*Module 1
score : 5
*module 2 :
score : 8
...
-Course B
*Module 1:
score 7
....
。我需要在课程和用户之间添加多对多的关系,因为我不知道哪个课程受哪个用户影响,因为他知道模块可以属于几个课程,在Utilisateur中添加course = models.ManyToManyField('Course')
是否正确?