首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在运行时创建Case()?

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

Stack Overflow用户
提问于 2019-02-26 20:28:46
回答 1查看 241关注 0票数 0

我想在运行时使用Case()。

代码语言:javascript
复制
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()

即使我做了

代码语言:javascript
复制
case = Case()

我不能使用Criterion将表达式插入其中。

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

EN

回答 1

Stack Overflow用户

发布于 2019-05-23 22:22:55

您可以尝试以下操作:

代码语言:javascript
复制
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))

输出应如下所示:

代码语言:javascript
复制
SELECT name,age,marks,CASE WHEN marks>=90 THEN 'A+' ELSE 'B+' END Grade FROM student
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54885610

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档