我只想找回“新”模型。基于is_new hybrid_method的值,模型是“新的”。
我认为,由于我处理的是对象而不是实例,这种方法对我来说是行不通的。我想我需要的是一个表达式,但我不知道如何为这个用例编写一个表达式。我基本上只想要不到30天前创建的模型。
MyModel
@hybrid_method
def is_new(self):
future = self.created_at + datetime.timedelta(days=30)
if datetime.datetime.now() < future:
return True
return False查询
MyModel.query.filter(MyModel.is_new() == True).all()误差
TypeError: Boolean value of this clause is not defined
发布于 2015-10-30 20:55:57
你需要用一个表达式。表达式必须返回布尔值。下面有一个用于从实例读取的hybrid_property和一个用于查询数据库的表达式。
模型
@hybrid_property
def is_new_product(self):
future = self.created_at + datetime.timedelta(days=30)
if datetime.datetime.now() < future:
return True
return False
@is_new_product.expression
def is_new_product(cls):
delta = datetime.timedelta(days=30)
return cls.created_at + delta > datetime.datetime.now()查询
ProductModel.query.filter(ProductModel.is_new_product==True).all()发布于 2015-10-30 20:14:49
使用hybrid_method时,需要通过方法的返回值进行筛选。
MyModel.query.filter(MyModel.is_new()).all()作为另一种选择,由于您不向is_new传递任何参数,所以可以使用hybrid_property。这将允许您执行比较。
@hybrid_property
def is_new(self):
...
MyModel.query.filter(MyModel.is_new == True).all()https://stackoverflow.com/questions/33443140
复制相似问题