【问题标题】:django annotate on select_related fielddjango 在 select_related 字段上注释
【发布时间】:2019-07-21 04:35:33
【问题描述】:

我的简化模型:

class Product(models.Model):
    name = models.CharField()

class Price(models.Model):
    product = models.OneToOneField('Product', primary_key=True)
    value = models.DecimalField()

class Cart(models.Model):
    product = models.ForeignKey('Product')
    qnt =  models.IntegerField()

我需要将两个字段相乘以存储在另一个字段中,即 sum 。为什么Cart.objects.select_related('product__price').annotate(sum=F('product__price__value') * F('qnt')) 什么都不返回?

F('') 替换为F('value') 返回错误

无法将关键字“值”解析为字段。选择是:cart_id, id、product、product_id、qnt

【问题讨论】:

  • 我在模型中使用了 @property 和 sum,并解决了它。但我想知道使用注释的相同解决方案。

标签: django annotate django-select-related


【解决方案1】:

您尝试将整数字段与小数字段相乘。因此,它会发生错误。你可以试试这个

from django.db.models import ExpressionWrapper, F, DecimalField


Cart.objects.select_related('product__price').annotate(
    sum= ExpressionWrapper(
        F('product__price__value') * F('qnt'), output_field=DecimalField()))

如果您组合的字段属于不同类型,您需要告诉 Django 将返回哪种类型的字段。由于 F() 不直接支持 output_field,因此您需要使用 ExpressionWrapper 包装表达式

【讨论】:

  • 不错。谢谢你。但为什么我没有抓住这个案子的例外?我用异常尝试。
  • 发生了哪些异常?
  • 关于类型的组合或其他。我想知道,为什么结果是空的。
猜你喜欢
  • 2020-12-15
  • 2019-09-03
  • 2018-03-21
  • 2012-01-15
  • 2014-05-18
  • 1970-01-01
  • 1970-01-01
  • 2019-01-22
  • 2011-08-27
相关资源
最近更新 更多