SQLAlchemy - 在查询中使用混合属性

19

我尝试像这样使用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()

这是一个 Flask 应用程序,它被这样调用:

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 我应该怎么做才能有所不同?
1个回答

28

你需要创建表达式

from sqlalchemy import func

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 - self.value)

    @dominance.expression
    def dominance(cls):
        return 1 - func.abs(0.5 - cls.value)

3
这个链接提供了一个相当不错的解释:https://docs.sqlalchemy.org/en/13/orm/mapped_sql_expr.html - user2682863
1
但是如果数据在实例级别上,并且对于每个对象都不同(在表达式中使用另一个混合属性),该怎么办? - MattSom

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接