如何在运行时创建Case()?

2024-05-23 17:43:09 发布

您现在位置:Python中文网/ 问答频道 /正文

我想在运行时生成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()

我无法使用条件将表达式插入其中。你知道吗

基本上,我想知道如何动态地创建when()语句,并在运行时决定运算符和操作数。你知道吗


Tags: namefromimportagetablequeryselectelse
1条回答
网友
1楼 · 发布于 2024-05-23 17:43:09

您可以尝试以下操作:

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 student

相关问题 更多 >