В Django у меня сложный запрос, где мне нужны только уникальные значения через внешний ключ, это возможно? - PullRequest
5 голосов
/ 24 июля 2010

У меня есть следующие модели:

class Indicator(models.Model):
    name = models.CharField(max_length=200)
    category = models.ForeignKey(IndicatorCategory)
    weight = models.IntegerField()
    industry = models.ForeignKey(Industry)

    def __unicode__(self):
        return self.name
    class Meta:
        ordering = ('name',)

class IndicatorRatingOption(models.Model):
    indicator = models.ForeignKey(Indicator)
    description = models.TextField()
    value = models.FloatField(null=True)

    def __unicode__(self):
        return self.description

class Rating(models.Model):
    product = models.ForeignKey(Product, null=True)
    company = models.ForeignKey(Company, null=True)
    rating_option = models.ForeignKey(IndicatorRatingOption)
    value = models.IntegerField(null=True)

Что мне нужно сделать, так это получить все варианты рейтинга компаний двух компаний, не перекрывая их показатели (rating.rating_option.indicator). В случае конфликта компания «а» всегда одержит победу над компанией «б». Как мне это сделать?

1 Ответ

5 голосов
/ 26 июля 2010

Это работает:

Rating.objects.filter(company__in=[company_a, company_b]).distinct()

(Оригинальный ответ)

Вы пробовали

IndicatorRatingOptions.objects.filter(company__in=[company_a, company_b]).distinct()

...