У меня есть эта модель:
class Visit(models.Model):
timestamp = models.DateTimeField(editable=False)
ip_address = models.IPAddressField(editable=False)
Если пользователь посещает несколько раз за один день, , как я могу фильтровать уникальные строки на основе поля ip? (я хочу уникальные посещения на сегодняшний день)
today = datetime.datetime.today()
yesterday = datetime.datetime.today() - datetime.timedelta(days=1)
visits = Visit.objects.filter(timestamp__range=(yesterday, today)) #.something?
EDIT:
Я вижу, что могу использовать:
Visit.objects.filter(timestamp__range=(yesterday, today)).values('ip_address')
чтобы получить ValuesQuerySet только для ip-полей. Теперь мой QuerySet выглядит так:
[{'ip_address': u'127.0.0.1'}, {'ip_address': u'127.0.0.1'}, {'ip_address':
u'127.0.0.1'}, {'ip_address': u'127.0.0.1'}, {'ip_address': u'127.0.0.1'}]
Как я могу отфильтровать это для уникальности, не оценивая QuerySet и принимая удар db?
# Hope it something like this...
values.distinct().count()