Django Admin Cookbook-8如何在Django admin中优化查询

Posted superhin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django Admin Cookbook-8如何在Django admin中优化查询相关的知识,希望对你有一定的参考价值。

8.如何在Django admin中优化查询?

如果你的Admin后台中有很多计算字段,那么你需要对每个对象运行多个查询,这会使你的Admin后台变得非常慢。要解决此问题,你可以重写管理模型中的get_queryset方法使用annotate聚合函数来计算相关的字段。

以下示例为Origin模型的中ModelAdmin管理模型:

@admin.register(Origin)
class OriginAdmin(admin.ModelAdmin):
    list_display = ("name", "hero_count", "villain_count")
    def hero_count(self, obj):
        return obj.hero_set.count()
    def villain_count(self, obj):
        return obj.villain_set.count()

这会在列表视图页面的每行添加两个额外的查询。要解决计算的性能问题,你可以重写get_queryset并使用annotate来进行计算,然后在ModelAdmin方法中使用该annotated聚合字段。

将ModelAdmin管理模型修改如下:

@admin.register(Origin)
class OriginAdmin(admin.ModelAdmin):
    list_display = ("name", "hero_count", "villain_count")
    def get_queryset(self, request):
        queryset = super().get_queryset(request)
        queryset = queryset.annotate(
            _hero_count=Count("hero", distinct=True),
            _villain_count=Count("villain", distinct=True),
        )
        return queryset
    def hero_count(self, obj):
        return obj._hero_count
    def villain_count(self, obj):
        return obj._villain_count

每个对象没有额外的查询。你的Admin后台用起来仍像调用annotate聚合函数前一样流畅。

技术图片

返回目录

以上是关于Django Admin Cookbook-8如何在Django admin中优化查询的主要内容,如果未能解决你的问题,请参考以下文章

Django Admin Cookbook-38如何获取特定对象的Django Admin后台URL

Django Admin Cookbook-23如何在Django admin中添加嵌套的内联

Django Admin Cookbook-18如何限制对Django Admin管理部分功能的使用

Django Admin Cookbook-17如何仅限特定用户登录Django Admin管理后台

Django Admin Cookbook-24如何从两个不同的模型创建一个Django Admin后台页面

如何在 django admin 中进行分类?