使用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 函数中。
答案 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()