我创建了一个模型'VehicleDetails',用户可以在其中填写车辆的详细信息,以及另一个模型'TripStatus',用于更新车辆位置。我想获得我在下面的代码中所做的最新位置。我在视图中使用prefetch_related来返回特定车辆的位置值。但是,在运行服务器之后,它会引发一个错误:“TripStatus对象没有属性'prefetch_related'”。我很乐意帮助我解决这个问题。 models.py:
class VehicleDetails(models.Model):
Vehicle_No = models.CharField(max_length=20)
class TripStatus(models.Model):
vehicledetails = models.ForeignKey(VehicleDetails, related_name='statuses')
CHOICES = (('Yet to start', 'Yet to start'),('Trip starts', 'Trip starts'), ('Chennai','Chennai'), ('Vizag', 'Vizag'), ('Kolkata', 'Kolkata'))
Vehicle_Status = models.CharField(choices=CHOICES, default="Yet to start", max_length=20)
statustime = models.DateTimeField(auto_now=False, auto_now_add=True)
views.py:
def status(request):
tripstatus = TripStatus.objects.all().latest('statustime').prefetch_related('statuses')
context = {
"tripstatus": tripstatus,
}
return render(request, 'loggedin_load/active_deals.html', context)
模板:
{% for status in vehicledetails.statuses.all %}
{{status.Vehicle_Status}}
{% endfor %}
答案 0 :(得分:3)
prefetch_related适用于queryset对象。最新返回单个模型而不是查询集。
这应该有效:
tripstatus = TripStatus.objects.all().prefetch_related('statuses').latest('statustime')