11

我确实将项目从 Django 1.6.7 更新到 1.8.7 并且我在 Django 1.8 中遇到了以下异常,尽管使用 Django 1.6 它的代码是正确的:

In[2]: from apps.route import models
In[3]: models.Trace.objects.select_related("trace_points")
Out[3]: <repr(<django.db.models.query.QuerySet at 0x3b50c10>) failed: django.core.exceptions.FieldError: Invalid field name(s) given in select_related: 'trace_points'. Choices are: user>

我的模型:

class Trace(SocialMixin, models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='traces')
    name = models.CharField(u'Название', max_length=255)
    rating = RatingField(range=5, weight=0)
    start_date = models.DateTimeField(u'Дата старта')
    finish_date = models.DateTimeField(u'Дата окончания', null=True, blank=True)
    distance = models.DecimalField(max_digits=15, decimal_places=6, null=True, blank=True)
    created = models.DateTimeField(auto_now_add=True)
    hits = generic.GenericRelation(HitCount, object_id_field='object_pk')
    description = models.TextField(null=True, blank=True)

class TracePoint(models.Model):
    country = models.ForeignKey(Country, null=True, blank=True)
    city = models.ForeignKey(City, null=True, blank=True)
    trace = models.ForeignKey(Trace, related_name="trace_points")

我在 Trace 上的 DetailView 中也有这个错误,DetailView 使用 get_related_selections,当然我得到“FieldError:无效的字段名称......”,为了避免错误我必须使用 ManyToManyField 而不是 ForeigenKey?

4

2 回答 2

18

Django 1.8检查 select_related 中给出的字段是否正确。该select_related方法可用于外键和一对一字段。不可能将其用于与 . 的反向Trace关系TracePoint

在以前的 Django 版本中,Trace.objects.select_related("trace_points")不会引发错误,但select_related()调用不会产生任何效果。

您可以删除select_related()呼叫,也可以将其替换为prefetch_related,这将起作用。

Trace.objects.prefetch_related('trace_points')
于 2016-05-05T09:15:45.543 回答
6

Djangoselect_related()不适用于反向外键关系。

您可能希望prefetch_related()用于在 python 级别预取所有跟踪点。

models.Trace.objects.prefetch_related("trace_points")
于 2016-05-05T09:14:57.120 回答