Spring XML使用CASE WHEN处理SELECT字段

在日常开发中,经常会碰到需要导出的情况。而一些枚举值或者状态一般是定义成整型,这个时候需要对数据进行转换,转换成对应的文本再导出。

在XML中用CASE WHEN来根据不同的查询结果做不同的处理。

比如
xml 复制代码
SELECT
name AS '姓名',
age AS '年龄'
CASE WHEN status = 1 THEN '在学' WHEN status = 2 THEN '休学' ELSE '辍学' END AS '学习状态'
FROM
student

这样,如果学生的状态值是1,则返回在学;如果状态值是2,则返回休学;如果是其他,则返回辍学。和Java开发中的if elseif else 差不多。

根据传入的参数不同做不同的处理。
xml 复制代码
SELECT
name AS '姓名',
age AS '年龄'
CASE WHEN #{kid}= 1 THEN max_score ELSE max_score+50 END AS '总分'
FROM
student 

如果传入的kid等于1,则直接放回总分;如果kid不等于1,则总分要在原来的基础上加50分。

尝试过使用if标签,不过if标签没法在select后面使用,只能在where后面使用。

相关推荐
e***95642 分钟前
springboot-自定义注解
java·spring boot·spring
管理大亨3 分钟前
Canal:企业数据实时同步的利器
数据库·mysql
白露与泡影11 分钟前
spring Security 认证流程闭环与调用链路详解
java·后端·spring
i***586712 分钟前
Java开发的AI应用框架简述——LangChain4j、Spring AI、Agent-Flex
java·人工智能·spring
i***279516 分钟前
SpringBoot实现异步调用的方法
java·spring boot·spring
r***934819 分钟前
PostgreSQL 向量扩展插件pgvector安装和使用
数据库·postgresql
阿在在19 分钟前
Dubbo 与 Spring 整合全流程解析(含生产者与消费者
java·spring·dubbo
z***677742 分钟前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
一辉ComeOn1 小时前
[源码系列:手写Spring] AOP第二节:JDK动态代理 - 当AOP遇见动态代理的浪漫邂逅
java·后端·spring
赵师的工作日1 小时前
MongoDB-从0到1-安全管理
数据库·安全·mongodb