Как создать Case () во время выполнения? - PullRequest
0 голосов
/ 26 февраля 2019

Я хочу сделать 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 () с операторами и операндами, определяемыми во время выполнения.

1 Ответ

0 голосов
/ 23 мая 2019

Вы можете попробовать следующее:

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
...