Django中的Prefetch问题

时间:2015-02-24 15:16:06

标签: python django django-queryset prefetch

我的Django应用程序中有当前模型:

class Referentiel(models.Model):
    code = models.CharField(max_length=50)
    libelle = models.CharField(max_length=100)


class Reference(models.Model):
    referentiel = models.ForeignKey('Referentiel', related_name='reference_set')
    clef = models.CharField(max_length=50)


class ValeurReference(models.Model):
    reference = models.ForeignKey('Reference', related_name='valeur_set')
    valeur = models.DecimalField(max_digits=15, decimal_places=5)
    date_fin = models.DateField(blank=True, null=True)

我希望检索Referentiel的值,所以我做了类似的事情:

Referentiel.objects.filter(code='whatever_code').prefetch_related(Prefetch('reference_set__valeur_set', to_attr='valeurs'))

但是在尝试获取我的值时出现以下错误:

AttributeError: 'Referentiel' object has no attribute 'valeurs'

Django版本:1.7.4 Python版本:3.4.2

感谢您的任何建议。

2 个答案:

答案 0 :(得分:0)

我认为您已使用queryset参数指定预取的自定义查询,并从那里预取valeur_set。

<强>更新

reference_qs = Reference.objects.prefetch('valeurreference_set').all()

    Referentiel.objects.filter(code='whatever_code')\
        .prefetch_related(
            Prefetch('reference_set', queryset=reference_qs, to_attr='valeurs')
        )

答案 1 :(得分:0)

我知道这是一个老问题,但是最近我也遇到了这样的错误。

问题是valeurs没有分配给Referentiel对象,而是分配给了reference_set

因此,在这种情况下,假设您具有这样的查询集:

queryset = (
    Referentiel
    .objects
    .filter(code='whatever_code')
    .prefetch_related(Prefetch('reference_set__valeur_set', to_attr='valeurs'))
)

代替:

queryset[0].valeurs

您必须这样做:

queryset[0].reference_set.all()[0].valeurs

不幸的是,to_attr可能会引起误解,并且文档中未提及带有嵌套查找的情况。