python - hybrid_property 表达式中的 if 语句

标签 python sqlalchemy conditional

我有一个 hybrid_property 执行一些条件并返回响应。我希望能够针对该字段进行查询,因此我创建了一个 expression。但是,我不确定如何为这种用例编写条件。

如何编写一个表达式,根据条件的结果将两个字段之一与另一个字段相乘?

@hybrid_property
def func(self):
    if self.some_column is True:
        return self.true_column * self.amount
    return self.false_column * self.amount

@func.expression
def func(cls):
    # ???
    return

最佳答案

你可以使用case表达

from sqlalchemy import case

@func.expression
def func(cls):
    return case(
        [
            (cls.some_column == True, cls.true_column * cls.amount),
        ],
        else_=cls.false_column * cls.amount
    )

关于python - hybrid_property 表达式中的 if 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34228471/

相关文章:

python - 如何引发多个非字段错误

php - 从命令行运行脚本和使用 PHP 从 exec() 运行脚本有什么区别?

Flask/SqlAlchemy 中的继承

vim - 如何使用vim进行条件替换

c++ - 为什么下面的代码只在 a = 1 时返回 true?

conditional - 如何有条件地在 TAL (PHPTAL) 中添加 id 属性?

python - tensorflow + 作业库 : limited to 8 processes?

python - 在 sqlalchemy 中使用 postgresql xml 数据类型

python - 当实例分配给关系时,sqlalchemy before_flush 事件处理程序看不到外键的变化

python - 使用 python 或 PowerShell 从 XML 代码中删除额外字符