Optimisation d'accès à la base de données

This commit is contained in:
Jean-Marie Favreau 2024-11-09 11:50:39 +01:00
parent 30c8811b05
commit b66f428a0e
4 changed files with 5 additions and 9 deletions

View File

@ -1039,17 +1039,13 @@ class Event(models.Model):
if self.other_versions is None: if self.other_versions is None:
return [] return []
else: else:
return Event.objects.filter( return [e for e in self.other_versions.get_duplicated() if e.pk != self.pk and e.status != Event.STATUS.TRASH]
other_versions=self.other_versions
).filter(~Q(status=Event.STATUS.TRASH)).exclude(pk=self.pk)
def get_other_versions(self): def get_other_versions(self):
if self.other_versions is None: if self.other_versions is None:
return [] return []
else: else:
return Event.objects.filter( return [e for e in self.other_versions.get_duplicated() if e.pk != self.pk]
other_versions=self.other_versions
).exclude(pk=self.pk)
def masked(self): def masked(self):
return self.other_versions and self.other_versions.representative != self return self.other_versions and self.other_versions.representative != self

View File

@ -86,7 +86,7 @@
</article> </article>
{% if event.other_versions %} {% if event.other_versions %}
{% with poss_dup=event.get_other_versions|only_allowed:user.is_authenticated %} {% with poss_dup=event.get_other_versions|only_allowed:user.is_authenticated %}
{% if poss_dup.count > 0 %} {% if poss_dup|length > 0 %}
<article id="liste-dupliques"> <article id="liste-dupliques">
<header> <header>
{% if event.other_versions.representative %} {% if event.other_versions.representative %}

View File

@ -20,7 +20,7 @@
</p> </p>
{% if event.other_versions %} {% if event.other_versions %}
{% with poss_dup=event.get_other_not_trash_versions|only_allowed:user.is_authenticated %} {% with poss_dup=event.get_other_not_trash_versions|only_allowed:user.is_authenticated %}
{% if poss_dup.count > 0 %} {% if poss_dup|length > 0 %}
<p class="remarque"> <p class="remarque">
{% if event.other_versions.representative %} {% if event.other_versions.representative %}
cet événement existe <a href="{% if user.is_authenticated %}{{ event.other_versions.get_absolute_url }}{% else %}#liste-dupliques{% endif %}">en plusieurs versions</a>, cet événement existe <a href="{% if user.is_authenticated %}{{ event.other_versions.get_absolute_url }}{% else %}#liste-dupliques{% endif %}">en plusieurs versions</a>,

View File

@ -150,6 +150,6 @@ def linebreaks2(txt):
@register.filter @register.filter
def only_allowed(elist, is_authenticated): def only_allowed(elist, is_authenticated):
if not is_authenticated: if not is_authenticated:
return elist.filter(status=Event.STATUS.PUBLISHED) return [e for e in elist if e.status == Event.STATUS.PUBLISHED]
else: else:
return elist return elist