Django管理员性能问题

时间:2012-03-15 12:26:48

标签: python django django-admin django-select-related

当我尝试在Django管理界面中打开一个模型时,我收到了数千个这样的查询,这导致严重的性能问题。

[sql] SELECT ... FROM `auth_user` WHERE `auth_user`.`id` = 9535
[sql] (21ms) Found 1 matching rows
[sql] SELECT ... FROM `auth_user` WHERE `auth_user`.`id` = 9536
[sql] (20ms) Found 1 matching rows

任何想法为什么Django管理员没有使用select_related()?

以下是(我认为)模型的相关部分(我正在查看管理员中学生模型的实例):

from django.contrib.auth.models import User

class Student(models.Model):
    user = models.OneToOneField(User, unique=True)
    mhtl_user = models.OneToOneField(MHTLUser, unique=True)
    def __str__(self):
        return u"%s %s" % (self.user.first_name, self.user.last_name)

class MHTLUser(models.Model):
    user = models.OneToOneField(User, unique=True)
    def __str__(self):
        return str(self.user)

2 个答案:

答案 0 :(得分:3)

或者只需启用list_select_related

class MyModelAdmin(admin.ModelAdmin):
    list_select_related = True
    # ....

答案 1 :(得分:2)

你可以通过像这样定义你自己的ModelAdmin来让Django使用select_related

class MyModelAdmin(admin.ModelAdmin):
    def queryset(self, request):
        qs = super(MyModelAdmin, self).queryset(request)
        return qs.select_related()