Как получить данные, возвращаемые предыдущим запросом в методе менеджера пользовательских классов? - PullRequest
1 голос
/ 19 сентября 2011

Я разработал собственный класс менеджера с цепным методом.Есть проблема.Мне нужно рандомизировать фильтрованный запрос.Чтобы получить случайную запись, мне нужно количество отфильтрованных и отдельных записей.Но я не знаю, как это получить.Напротив, у меня есть счетчик всех записей.

class RandomQueryset(models.query.QuerySet):

    def randomize(self):        
        count = self.aggregate(count=Count('id'))['count']
        random_index = random.randint(0, count - 1)
        return self.all()[random_index]    


class RandomManager(models.Manager):

    def get_query_set(self):
        return RandomQueryset(self.model, using=self._db)

    def randomize(self):
        return self.get_query_set().randomize()

Использование:

>>> posts = PostPages.random_objects.filter(image_gallery__isnull=False).distinct()

>>> posts.randomize()

Рано или поздно я получаю ошибку, потому что это число превышает количество записей в текущемзапрос.

IndexError: list index out of range

1 Ответ

1 голос
/ 23 сентября 2011

Вы попросили меня опубликовать один из моих вопросов в качестве ответа, так что вот так.

Похоже, вам нужно использовать встроенную в Django функцию count () docs.djangoproject.com / en / dev / ref / models / querysets

Я не вижу его использования в вашем коде.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...