当我尝试在 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() 有什么想法吗?
以下是(我认为)模型的相关部分(我正在查看管理员中的 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)