gpt4 book ai didi

python - 提高 Django 管理列表过滤器查询的性能

转载 作者:行者123 更新时间:2023-12-03 15:01:58 25 4
gpt4 key购买 nike

我正在围绕 PostgreSQL 数据仓库应用程序开发 Django 管理包装器,该应用程序有一些包含数百万条记录的表。

没有任何列表过滤器的管理员更改列表页面会在一秒钟内加载,但是如果我在管理员的 list_filters 中包含某些列,它加载非常缓慢,加载可能需要 30 秒到 1 分钟。

检查数据库,我看到了几个查询,如:

SELECT DISTINCT "warehouse_data"."filter_field1" FROM "warehouse_data" ORDER BY "warehouse_data"."filter_field1" ASC;

每一个只需要 3-5 秒,但是有十几个,这些加起来。所有字段都被编入索引,所以我不知道我还能如何加快它们的速度。如何提高管理性能?我将如何插入 Django 的缓存机制来缓存这些列表过滤器的实际查询?

最佳答案

正如你所观察到的;缓慢来自 django 编译唯一值列表,以便它可以在侧边栏中显示它们。

在幕后,这需要对数据库进行全表扫描,当您的表非常大时,这会很昂贵。如果您将此字段用作 list_filter;很有可能唯一值的数量很少,并且您可以自己更有效地生成唯一值列表(假设您知道这些值的来源)。为此,您可以定义自定义 list_filter。

来自 the docs (为简洁而浓缩):

list_filter should be a list or tuple of elements, where each element should be of one of the following types:

  • a field name
  • a class inheriting from django.contrib.admin.SimpleListFilter

from datetime import date
from django.contrib import admin
from django.utils.translation import gettext_lazy as _

class DecadeBornListFilter(admin.SimpleListFilter):
title = _('decade born')
parameter_name = 'decade'

def lookups(self, request, model_admin):
return (
('80s', _('in the eighties')),
('90s', _('in the nineties')),
)

def queryset(self, request, queryset):
# Compare the requested value (either '80s' or '90s')
# to decide how to filter the queryset.
if self.value() == '80s':
return queryset.filter(birthday__gte=date(1980, 1, 1),
birthday__lte=date(1989, 12, 31))
if self.value() == '90s':
return queryset.filter(birthday__gte=date(1990, 1, 1),
birthday__lte=date(1999, 12, 31))

class PersonAdmin(admin.ModelAdmin):
list_filter = (DecadeBornListFilter,)

关于python - 提高 Django 管理列表过滤器查询的性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22080469/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com