I have this model:
class UserMovieRel(models.Model):
user = models.ForeignKey("register.User", on_delete=models.CASCADE)
movie = models.ForeignKey("Movie", on_delete=models.CASCADE, related_name="users")
rating = models.PositiveIntegerField(
validators=[MinValueValidator(1), MaxValueValidator(10)], null=True, blank=True
)
advice = models.CharField(max_length=500, null=True, blank=True)
objects = UserMovieRelManager()
def __str__(self) -> str:
return f"{self.user} - {self.movie} (rating: {self.rating or 'n/a'})"
class Meta:
constraints = [
models.UniqueConstraint(fields=["user", "movie"], name="user_movie_unique"),
]
I'm trying to get the avg rating for each movie in this way:
avg_ratings = UserMovieRel.objects.filter(movie_id=OuterRef("movie_id")).exclude(rating__isnull=True).annotate(avg_rating=Avg("rating"))
UserMovieRel.objects.annotate(avg_rating=Subquery(avg_ratings[0]))
but it fails:
ValueError: This queryset contains a reference to an outer query and may only be used in a subquery.
I've tried also with aggregation:
UserMovieRel.objects.annotate(
avg_rating=Subquery(
UserMovieRel.objects.filter(
movie_id=OuterRef("movie_id")
).aggregate(
avg_rating=Avg("rating")
)["avg_rating"]
)
)
but I've got the same error.
any help on this? Thanks