ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python-Django queryset优化:使用过滤器对_set进行反向查找

2019-11-11 07:06:39  阅读:265  来源: 互联网

标签:postgresql python django


我有这些模型,我需要做一些计算并将其呈现给用户.我渲染了大约2-3k的行,这导致对数据库进行了4k个查询(如调试工具栏所示).有什么办法可以优化这个?我已经尝试过prefetch_related,但是它只是在已经完成的4k之上添加了另一个查询.

class Cart(models.Model):
    name = models.CharField(max_length=15)
    user = models.OneToOneField(User)


    def sum_for_this(self, taxtype, tax):
        return self.carttax_set.filter(tax__type__name=taxtype,
                                       tax__tax=tax).aggregate(
            sum=Coalesce(Sum('tax_amount'), Value('0'))
        ).get('sum')


class TaxType(models.Model):
    name = models.CharField(max_length=10)


class Tax(models.Model):
    name = models.CharField(max_length=100)
    type = models.ForeignKey(TaxType)
    tax = models.DecimalField()


class CartTax(models.Model):
    cart = models.ForeignKey(Cart)
    tax = models.ForeignKey(Tax)
    base = models.IntegerField()
    tax_amount = models.IntegerField()

我在模板中所做的是:

{% for cart in cartlist %}
{{ cart.sum_for_this }}
{% endfor %}

我已经尝试过但没有效果:

Cart.objects.prefetch_related('carttax_set').all()

该方法def sum_for_this正在执行所有查询.

解决方法:

尝试对conditional expressions使用注释.查询将如下所示:

from django.db.models import Q, F, Sum, Case, When, IntegerField
from django.db.models.functions import Coalesce


cartlist = Cart.objects.annotate(
    sum=Coalesce(Sum(Case(
        When(Q(carttax__tax__type__name=taxtype) & Q(carttax__tax__tax=tax), then=F('carttax__tax_amount')),
        output_field=IntegerField()
        )), 0)
    )

并在模板中:

{% for cart in cartlist %}
{{ cart.sum }}
{% endfor %}

标签:postgresql,python,django
来源: https://codeday.me/bug/20191111/2018359.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有