我有一个预订系统,并将预订的日期范围保存在 DATERANGE 列中:
booked_date = Column(DATERANGE(), nullable=False)
我已经知道我可以使用booked_date.lower或访问实际日期booked_date.upper
例如,我在这里这样做:
for bdate in room.RoomObject_addresses_UserBooksRoom:
unaviable_ranges['ranges'].append([str(bdate.booked_date.lower),\
str(bdate.booked_date.upper)])
现在我需要按给定的日期范围过滤我的预订。例如,我想查看 01.01.2018 和 10.01.2018 之间的所有预订。
通常它很简单,因为日期可以这样比较: date <= other date
但是如果我用 DATERANGE 来做:
the_daterange_lower = datetime.strptime(the_daterange[0], '%d.%m.%Y')
the_daterange_upper = datetime.strptime(the_daterange[1], '%d.%m.%Y')
bookings = UserBooks.query.filter(UserBooks.booked_date.lower >= the_daterange_lower,\
UserBooks.booked_date.upper <= the_daterange_upper).all()
我收到一个错误:
AttributeError: Neither 'InstrumentedAttribute' object nor 'Comparator' object associated with UserBooks.booked_date has an attribute 'lower'
编辑
我找到了一个带有有用范围运算符的工作表,看起来有更好的选择来做我想做的事情,但为此我需要以某种方式创建一个range variable,但 python 不能这样做。所以我还是很困惑。
在我的数据库中,我的 daterange 列条目如下所示:
[2018-11-26,2018-11-28)
编辑
我正在尝试使用本机 SQL 而不是 sqlalchemy,但我不明白如何创建 daterange 对象。
bookings = db_session.execute('SELECT * FROM usersbookrooms WHERE booked_date && [' + str(the_daterange_lower) + ',' + str(the_daterange_upper) + ')')
弑天下
相关分类