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

摘要:
如果Admin后台中有许多计算字段,则需要对每个对象运行多个查询,这将使Admin后台非常缓慢。以下示例是Origin模型中的ModelAdmin管理模型:@admin。registerPassOriginAdmin:list_display=defhero_count:returnobj。hero_集合。count()defvillain_count:返回对象。邪恶的集合。Count()这将为列表视图页面的每行添加两个附加查询。为了解决计算的性能问题,可以重写get_Queryset并使用annotation进行计算,然后在ModelAdmin方法中使用带注释的聚合字段。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中优化查询第1张

返回目录

免责声明:文章转载自《Django Admin Cookbook-8如何在Django admin中优化查询》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇端口被占用2018-2019-2 20175126谢文航 实验三《敏捷开发与XP实践》实验报告下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

django 日志logging的配置以及处理

日志在程序开发中是少不了的,通过日志我们可以分析到错误在什么地方,有什么异常。在生产环境下有很大的用途。在Java开发中通常用log4j,logback等第三方组件。那么在django中是怎么处理日志?django利用的就是Python提供的logging模块,但django中要用logging,还得有一定的配置规则,需要在setting中设置。 log...

docker部署django项目、mysql主从搭建、django实现读写分离

目录 docker部署django项目 1.1 基于python基础镜像 将本地django项目打包并发到远程服务器上 将服务器上的.zip django项目解压 部署的具体流程 1.2 基于dockerfile 2 mysql主从搭建 一 主从配置原理 二 操作步骤 2.1我们准备三台装好mysql的服务器(我在此用docker模拟...

Django中获取URL路径参数(路径,查询,请求头,请求体)

通常HTTP协议向服务器传参有几种途径 :   提取URL的特定部分,如/weather/shanghai/2018,可以在服务器端的路由中用正则表达式截取;   查询字符串(query string),形如key1=value1&key2=value2;   请求体(body)中发送的数据,比如表单数据、json、xml;   在http报文的头...

异步任务分发模块Celery

Celery简介 Celery是一个功能完备即插即用的任务队列。它使得我们不需要考虑复杂的问题,使用非常简单。 celery适用异步处理问题,当遇到发送邮件、或者文件上传, 图像处理等等一些比较耗时的操作,我们可将其异步执行,这样用户不需要等待很久,提高用户体验。 celery的特点是: 简单,易于使用和维护,有丰富的文档。 高效,单个celery进程每...

Django文件配置及orm

http协议 -特点:    1 基于TCP/IP协议之上的应用层协议    2 基于请求-响应模式    3 无状态保存    4 无连接 -请求头: 请求首行 get / http/1.1 key:value key:value 请求体的内容 -响...

华为存储设备管理ip修改

存储设备的常用知识 1.管理网口的ip地址 控制器A的ip地址192.168.128.101 控制器B的ip地址192.168.128.102 2.维护端口i默认为 172.31.128.101或172.31.128.102 3.默认的用户名和密码 用户名:admin 密码:Admin@storage 4.登陆华为默认OceanStor DeviceM...