我的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
感谢您的任何建议。
答案 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
可能会引起误解,并且文档中未提及带有嵌套查找的情况。