我正在尝试使用像这样的SQLAlchemy混合属性
class Metric(Base):
__tablename__ = 'metric'
id = Column(Integer, primary_key=True)
value = Column(Float, nullable=False)
@hybrid_property
def dominance(self):
return 1 - abs(0.5 - float(self.value))
现在,我把这个用在我的模型上
class MetricModel(BaseModel):
def get_dominance(self):
self.query(Metric).filter(Metric.dominance > 0.5).order_by(Metric.dominance.desc()).limit(2).all()
这是一个烧瓶应用程序,它的名字是这样的
model = MetricModel(db)
with db.session():
print(model.get_dominant_traits())
这给了我一个错误
TypeError: float() argument must be a string or a number, not 'InstrumentedAttribute'
从错误来看,似乎没有结果集,因此失败。我跟踪了这里的文档http://docs.sqlalchemy.org/en/latest/orm/extensions/hybrid.html
我该怎么做呢?
你需要创建expression
相关问题 更多 >
编程相关推荐