Django ORM内部模型标签-速度

时间:2019-03-11 20:27:52

标签: django django-models

使用Django 1.11和python 2.7, 我有一个沉重的Django Admin App,代码如下:

    # same as __str__ in python 3
    def __unicode__(self):
    redirected = "REDIRECTED-" if self.is_redirected else ""
    return u'[{}{}] {}'.format(redirected, self.typecode, self.headline)


    @property
    def is_redirected(self):
        return OtherModel.objects.filter(old_path=self.url).exists()

问题是因为模型标签(打印对象时默认作为输出的名称)在管理模板的很多地方使用,因此每次调用ORM都会耗费〜200ms的时间,总计8时间到每页约2秒,我想加快速度并减少通话。

显而易见的答案是缓存,但是调用缓存也需要花费时间,因为它位于不同的服务器上,因此除了获得8个SQL调用外,我还将获得8个外部请求,这是我要避免的另一件事。

我不会详细说明,但我需要将所有内容保留在 unicode 函数中。

1 个答案:

答案 0 :(得分:1)

您可能可以使用Exists注释。

from django.db.models import OuterRef, Exists

class NewModelAdmin(admin.ModelAdmin):
    def get_queryset(self, request):
        queryset = super(NewModelAdmin, self).get_queryset(request)
        old_model = OldModel.objects.filter(old_path=OuterRef('url'))
        return queryset.annotate(
            has_old_model=Exists(old_model),
        )


class NewModel(models.Model):
    ...
    @property
    def is_redirected(self):
        if hasattr(self, 'has_old_model'):
            return self.has_old_model
        # Fall back to previous method if you're worried
        # you don't have all paths covered.
        return OtherModel.objects.filter(old_path=self.url).exists()