2

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() を使用していない理由はありますか?

ここに (私が思うに) モデルの関連部分があります (私は admin で Student モデルのインスタンスを見ています):

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)
4

2 に答える 2

3

または、list_select_relatedを有効にします。

class MyModelAdmin(admin.ModelAdmin):
    list_select_related = True
    # ....
于 2012-03-15T13:31:31.603 に答える
2

このように独自の ModelAdmin を定義することで、Django に select_related を使用させることができます。

class MyModelAdmin(admin.ModelAdmin):
    def queryset(self, request):
        qs = super(MyModelAdmin, self).queryset(request)
        return qs.select_related()
于 2012-03-15T12:37:49.983 に答える