Как вычислить среднюю разницу между полями datetime из связанной таблицы в django?
У меня есть две модели Gigs и Orders. и я хочу вычислить среднее значение разницы между временем начала_заказа и временем завершения_заказа каждого концерта. проверьте мой код, он выдает следующую ошибку
Не удается подобрать ключевое слово 'orders' к полю. Варианты: category, category_id, details, gig, id, images, price, reviews, seller, seller_id, title
прошу помощи!
Models.py (in seller app)
class Gigs(models.Model):
title = models.CharField(max_length=255)
category = models.ForeignKey(Categories , on_delete=models.CASCADE)
images = models.ImageField(blank=True, null = True, upload_to= upload_path)
price = models.DecimalField(max_digits=6, decimal_places=2)
details = models.TextField()
seller = models.ForeignKey(User,default=None, on_delete=models.CASCADE)
@property
def average_completionTime(self):
if self._average_completionTime is not None:
return self._average_completionTime
return self.gig.aggregate(Avg('order_completed_time'-'order_start_time'))
Я думаю, что здесь проблема в среднем времени завершения, как я могу использовать 'order_completed_time'-'order_start_time' в одной переменной, на которую я должен ссылаться в views.py
Models.py(in buyer app)
фокус на поле элемента
from seller.models import Gigs
class Orders(models.Model):
buyer = models.ForeignKey(User,default=None, on_delete=models.CASCADE,related_name='buyer_id')
seller = models.ForeignKey(User,default=None, on_delete=models.CASCADE,related_name='seller_id')
item = models.ForeignKey(Gigs,default=None, on_delete=models.CASCADE,related_name='gig')
payment_method= models.CharField(max_length=10)
address = models.CharField(max_length=255)
mobile = models.CharField(max_length=13,default=None)
quantity = models.SmallIntegerField(default=1)
status = models.CharField(max_length=13,default='new order')
order_start_time = models.DateTimeField(default=None)
order_completed_time = models.DateTimeField(default=None)
created_at = models.DateTimeField(auto_now_add=True)
Views.py
class RetrieveGigsAPI(GenericAPIView, RetrieveModelMixin):
def get_queryset(self):
return Gigs.objects.all().annotate(_average_rating=Avg('orders__time'))
serializer_class = GigsSerializerWithAvgTime
permission_classes = (AllowAny,)
def get(self, request , *args, **kwargs):
return self.retrieve(request, *args, **kwargs)
Serializers.py
class GigsSerializerWithAvgTime(serializers.ModelSerializer):
average_completionTime = serializers.SerializerMethodField()
def get_average_completionTime(self, obj):
return obj.average_completionTime
class Meta:
model = Gigs
fields = ['id','title','category','price','details','seller','images','average_completionTime']
Объект F() представляет значение поля модели, он ссылается на значения полей модели и выполняет операции базы данных, используя их. для более подробной информации https://docs.djangoproject.com/en/3.2/ref/models/expressions/#f-expressions
from django.db.models import F
let say queryset = Gigs.objects.all()
queryset.aggregate(Avg(F('order_completed_time') -F('order_start_time')))
Вы можете указать среднее время выполнения каждого задания следующим образом:
def get_queryset(self):
return Gigs.objects.annotate(
_average_completionTime=Avg(
F('gig__order_completed_time') - F('gig__order_start_time')
)
)
В вашем методе модели average_completionTime
также необходимо использовать выражения F
, если self._average_completionTime
не задано так:
@property
def average_completionTime(self):
if getattr(self, '_average_completionTime', None):
return self._average_completionTime
return self.gig.aggregate(Avg(F('order_completed_time') - F('order_start_time')))