我想在运行时使用Case()。
from pypika import Query, Table
table = Table('student')
query = Query.from_(table).select(table.name,
table.age,
table.marks,
Case()
.when(table.marks >= 90, 'A+')
.else('B+').as_('GRADE')
)
print query.get_sql()即使我做了
case = Case()我不能使用Criterion将表达式插入其中。
基本上,我想知道如何动态创建when()语句,并在运行时决定运算符和操作数。
发布于 2019-05-23 22:22:55
您可以尝试以下操作:
table = Table('student')
query = Query.from_(table)
case = Case()
case = case.when(table.marks >= 90,'A+')
case = case.else_('B+').as_('Grade')
query = query.select(table.name,
table.age,
table.marks,case)
print(query.get_sql(quote_char=None))输出应如下所示:
SELECT name,age,marks,CASE WHEN marks>=90 THEN 'A+' ELSE 'B+' END Grade FROM studenthttps://stackoverflow.com/questions/54885610
复制相似问题