2

我有一个简单的事件模型,它具有 start_date 和 end_date,关键部分是日期范围必须是唯一的。

出于这个原因,我编写了查询(Q)过滤器来检查日期范围是否唯一。无论如何,我的问题在于视图部分;当用户来到带有初始日期的事件添加页面时,我需要创建一个事件对象,(用户可以稍后根据日期范围的唯一性对其进行更改)

如何决定(过滤)哪些天不包含在任何 Event 对象中?或者如果这个月有任何可用的日期?使用 django 过滤器或一些聪明的方法......

#model:
class Event(models.Model):

    user = models.ForeignKey(User)
    start_date = models.DateTimeField()
    end_date = models.DateTimeField()
    status = models.IntegerField(default=0)

    def save(self, *args, **kwargs):
        try:
            Event.objects.get(
                Q(user=self.user, status=1),
                Q(start_date__range=(self.start_date, self.end_date))
                |Q(end_date__range=(self.start_date, self.end_date))
                |Q(start_date__lte=self.start_date, end_date__gte=self.end_date)
            )
            raise IntegrityError("Error message")
        except Event.DoesNotExist:
            super(Event,self).save(*args,**kwargs)

在我看来:有一个函数用于创建具有初始日期的 Event 对象并重定向到 url,用于更新/编辑事件详细信息。

#view:
try:
    event = Event.objects.create(user=request.user,
                                 start_date=datetime.date.today(), 
                                 end_date=datetime.date.today())
except IntegrityError, e:
    return HttpResponse(e)

ps:如果有更聪明的方法和一些不同的设计方法,我会很高兴听到。

4

1 回答 1

2

不是你问题的核心,但请注意,你没有在MultipleObjectsReturned这里讨论这个案例:

    try:
        Event.objects.get(
            Q(user=self.user, status=1),
            Q(start_date__range=(self.start_date, self.end_date))
            |Q(end_date__range(self.start_date, self.end_date))
            |Q(start_date__lte=self.start_date, end_date__gte=self.end_date)
        )
        raise IntegrityError("Error message")
    except Event.DoesNotExist:
        super(Event,self).save(*args,**kwargs)

我觉得会更好

    if Event.objects.filter(
        Q(user=self.user, status=1),
        Q(start_date__range=(self.start_date, self.end_date))
        | Q(end_date__range(self.start_date, self.end_date))
        | Q(start_date__lte=self.start_date, end_date__gte=self.end_date)
    ):
        raise IntegrityError("Error message")
    else:
        super(Event,self).save(*args,**kwargs)
于 2012-05-14T02:36:01.073 回答