1

私は SchoolClass と Student の 2 つのモデルを持っています。これらは Enrollment モデルを通じて多対多の関係にあります。

class Student(models.Model):
    name = models.CharField(max_length=100)
    code = models.CharField(max_length=10)

class SchoolClass(models.Model):
    code = models.CharField(max_length=100)
    cycle = models.ForeignKey(Cycle)
    students = models.ManyToManyField(Student,through='Enrolment')

class Enrolment(models.Model):
    student = models.ForeignKey(Student)
    school_class = models.ForeignKey(SchoolClass)

SchoolClass モデルには、フィールド サイクル (クラスが実行される年 + 学期) があります。管理者で学生を表示するとき、学生が特定のサイクル (たとえば、現在のサイクル)

私は以前、登録モデルにサイクル フィールドを持っていましたが、次のようにするとうまくいきました。

class StudentEnrolmentsInlineFormSet(BaseInlineFormSet):
    def get_queryset(self):
        if not hasattr(self, '_queryset'):
            qs = super(StudentInlineFormSet, self).get_queryset().filter(cycle=Current)
            self._queryset = qs
        return self._queryset

class StudentEnrolmentsInline(admin.TabularInline):
    model = Enrolment
    formset = StudentEnrolmentsInlineFormSet

class StudentAdmin(admin.ModelAdmin):
    form = StudentForm
    inlines = (StudentEnrolmentsInline,)

ただし、SchoolClass モデルのサイクルを移動したため、フィルターを次のモデルに適用する方法がわかりません。

4

1 に答える 1

2

私が何かを見落としていない限り、querysetStudentEnrolmentsInline のメソッドでこれを行うことができます。

def queryset(self, request):
    current = Cycle.objects.latest() # or whatever to get the current cycle
    qs = super(StudentEnrolmentsInline, self).queryset(request)
    return qs.filter(school_class__cycle=current)
于 2013-05-02T23:35:00.613 に答える