mai*_*_73 4 python mysql django django-admin
我遇到了一个问题.
当我尝试打开更改页面以查看元素内的参数(例如djangosite.com/admin/djangoapp/someelement/1/change/)时,它加载速度非常慢(10-15秒).
我发现Django正在进行大量重复查询:
更新: 我认为我在admin.py中犯了错误.
inlines = [PhoneInline,FlatInline,NeedInline]
Run Code Online (Sandbox Code Playgroud)
如果我删除上面的一切都很好.
mysql日志
2161 Query set autocommit=0
2161 Query SELECT `ha_phone`.`id`, `ha_phone`.`phone_number`, `ha_phone`.`phone_owner_id` FROM `ha_phone` WHERE `ha_phone`.`id` = 262
2161 Query SELECT `django_content_type`.`id`, `django_content_type`.`app_label`, `django_content_type`.`model` FROM `django_content_type` WHERE (`django_content_type`.`model` = 'phone' AND `django_content_type`.`app_label` = 'MYAPP')
2161 Query commit
2161 Query set autocommit=1
2161 Query SELECT `ha_owner`.`id`, `ha_owner`.`owner_pub_date`, `ha_owner`.`owner_name`, `ha_owner`.`owner_verify`, `ha_owner`.`owner_company_id` FROM `ha_owner` WHERE `ha_owner`.`id` = 236
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_owner`.`id`, `ha_owner`.`owner_pub_date`, `ha_owner`.`owner_name`, `ha_owner`.`owner_verify`, `ha_owner`.`owner_company_id` FROM `ha_owner`
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
2161 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company` WHERE `ha_company`.`id` = 1
...
Run Code Online (Sandbox Code Playgroud)
models.py
class House(models.Model):
house_number = models.CharField(max_length=10, verbose_name="????? ????")
house_floors = models.PositiveSmallIntegerField(verbose_name="????? ??????", null=True)
house_walls = models.ForeignKey(Walls, verbose_name="???????? ????", null=True)
house_street = models.ForeignKey(Street, verbose_name="?????")
house_metro = models.ForeignKey(Metro, verbose_name="??????? ?????", null=True)
house_block = models.ForeignKey(Block, verbose_name="??????????", null=True)
class Meta:
verbose_name = '???'
verbose_name_plural = '????'
ordering = ['house_street','house_number']
def __unicode__(self):
return unicode(self.house_street.street_name) + " " + unicode(self.house_number)
class Flat(models.Model):
flat_number = models.CharField(max_length=7, verbose_name="????? ????????", null=True)
flat_rooms = models.PositiveSmallIntegerField(verbose_name="????? ??????")
flat_total_sq = models.PositiveSmallIntegerField(verbose_name="????? ???????")
flat_life_sq = models.PositiveSmallIntegerField(verbose_name="????? ???????")
flat_kitchen_sq = models.PositiveSmallIntegerField(verbose_name="???????? ???????")
flat_floors = models.PositiveSmallIntegerField(verbose_name="????")
flat_house = models.ForeignKey(House, verbose_name="???")
flat_owner = models.ForeignKey(Owner, verbose_name="????????")
flat_comment = models.TextField(verbose_name="??????????", null=True)
flat_price = models.PositiveIntegerField(verbose_name='???? ????????')
...
class Owner(models.Model):
owner_pub_date = models.DateField(default=None,null=True,verbose_name="???? ??????????")
owner_name = models.CharField(max_length=150, verbose_name="??? ?????????")
owner_verify = models.BooleanField(verbose_name="???????????? ??????????????")
owner_company = models.ForeignKey(Company, verbose_name="????????")
class Meta:
verbose_name = '?????????'
verbose_name_plural = '?????????'
def __unicode__(self):
return unicode(self.id) + " | "+ self.owner_name + " " + unicode(self.owner_company)
class Phone(models.Model):
phone_number = models.CharField(max_length=25, verbose_name="????? ????????")
phone_owner = models.ForeignKey(Owner, verbose_name="???????? ????????")
class Meta:
verbose_name = '???????'
verbose_name_plural = '????????'
def __unicode__(self):
return unicode(self.phone_owner) + " " + self.phone_number
Run Code Online (Sandbox Code Playgroud)
admin.py
...
class PhoneInline(admin.StackedInline):
model = Phone
extra = 2
class FlatInline(admin.TabularInline):
model = Flat
extra = 0
class NeedInline(admin.TabularInline):
model = Need
extra = 1
class OwnerAdmin(admin.ModelAdmin):
field=['owner_name']
inlines = [PhoneInline,FlatInline,NeedInline]
admin.site.register(Owner,OwnerAdmin)
Run Code Online (Sandbox Code Playgroud)
我该怎么办?非常感谢你.
更新 @Alasdair,谢谢.使用ha_company的查询减少了.但我和ha_street有另外一个重复.看起来像这样:
2601 Query SELECT `ha_company`.`id`, `ha_company`.`company_name` FROM `ha_company`
2601 Query SELECT `ha_house`.`id`, `ha_house`.`house_number`, `ha_house`.`house_floors`, `ha_house`.`house_walls_id`, `ha_house`.`house_street_id`, `ha_house`.`house_metro_id`, `ha_house`.`house_block_id`, `ha_house`.`house_age`, `ha_house`.`house_flat`, `ha_house`.`house_quality` FROM `ha_house` INNER JOIN `ha_street` ON (`ha_house`.`house_street_id` = `ha_street`.`id`) ORDER BY `ha_street`.`street_name` ASC, `ha_house`.`house_number` ASC
2601 Query SELECT `ha_street`.`id`, `ha_street`.`street_name` FROM `ha_street` WHERE `ha_street`.`id` = 74
2601 Query SELECT `ha_street`.`id`, `ha_street`.`street_name` FROM `ha_street` WHERE `ha_street`.`id` = 74
2601 Query SELECT `ha_street`.`id`, `ha_street`.`street_name` FROM `ha_street` WHERE `ha_street`.`id` = 36
2601 Query SELECT `ha_street`.`id`, `ha_street`.`street_name` FROM `ha_street` WHERE `ha_street`.`id` = 582
2601 Query SELECT `ha_street`.`id`, `ha_street`.`street_name` FROM `ha_street` WHERE `ha_street`.`id` = 582
Run Code Online (Sandbox Code Playgroud)
模型的__unicode__方法Phone包括unicode(self.phone_owner),进而访问owner_company外键.这意味着Django必须为内联中的每个电话对象查找公司.
您通过删除内联来解决问题,但如果您想保留内联,您可以:
__unicode__方法Phone或Owner不包括公司覆盖get_queryset内联的方法,以便您可以使用select_related.
class PhoneInline(admin.StackedInline):
model = Phone
extra = 2
def get_queryset(self, request):
return super(PhoneInline, self).get_queryset(request).select_related('phone_owner', 'phone_owner__ owner_company')
Run Code Online (Sandbox Code Playgroud)| 归档时间: |
|
| 查看次数: |
1651 次 |
| 最近记录: |