diff options
author | Alban Gruin | 2017-10-20 13:29:07 +0200 |
---|---|---|
committer | Alban Gruin | 2017-10-20 13:29:07 +0200 |
commit | 07e9a1d1e6c77d64e5c3daf0324ae751117f168e (patch) | |
tree | d5691d98844954b1a1490cf09e1a140322cd9533 /models.py | |
parent | 276dc9017b414404539b20f32bcc65959fd32adb (diff) |
Modification de la requĂȘte qui sĂ©lectionne les groupes pertinents.
Diffstat (limited to 'models.py')
-rw-r--r-- | models.py | 21 |
1 files changed, 9 insertions, 12 deletions
@@ -16,7 +16,8 @@ from functools import reduce from django.db import models -from django.db.models import Count, Manager, Q +from django.db.models import Count, Manager, Q, Subquery +from django.db.models.expressions import OuterRef from django.db.models.functions import ExtractWeek, ExtractYear from django.utils import timezone from django.utils.text import slugify @@ -69,17 +70,13 @@ class Timetable(SlugModel): class GroupManager(Manager): - def get_relevant_children(self, group): - parent_in = self.get_queryset().filter(parent=group) - return self.get_queryset().filter(Q(parent=group) | Q(parent__in=parent_in)) \ - .annotate(children_count=Count("children")) \ - .filter(children_count=0, hidden=False) \ - .order_by("name") - - def get_relevant_groups(self, *args, **criteria): - return self.get_queryset().filter(*args, **criteria) \ - .annotate(children_count=Count("children")) \ - .filter(children_count=0, hidden=False) + def get_relevant_groups(self, timetable, *args, **criteria): + sub = Group.objects.filter(timetable=timetable,mention=OuterRef("mention"), + subgroup__startswith=OuterRef("subgroup")) \ + .order_by().values("mention").annotate(c=Count("*")).values("c") + return Group.objects.filter(*args, timetable=timetable, hidden=False, **criteria) \ + .annotate(nbsub=Subquery(sub, output_field=models.IntegerField())) \ + .filter(nbsub=1).order_by("name") class Group(models.Model): |