mybatis xml mapper 文件中 if-else 写法
mybaits 中没有else要用chose when otherwise 代替
范例一
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | <!--批量插入用户--> < insert id="insertBusinessUserList" parameterType="java.util.List"> insert into `business_user` (`id` , `user_type` , `user_login` ) values < foreach collection="list" index="index" item="item" separator=","> < trim prefix="(" suffix=")" suffixOverrides=","> < choose > < when test="item.id != null and item.id !=''"> #{item.id,jdbcType=CHAR}, </ when > < otherwise > '', </ otherwise > </ choose > < choose > < when test="item.userType != null and item.userType !=''"> #{item.userType,jdbcType=VARCHAR}, </ when > < otherwise > '', </ otherwise > </ choose > </ trim > </ foreach > </ insert > |
其中choose为一个整体
when是if
otherwise是else
范例二:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | < select id="selectSelective" resultMap="xxx" parameterType="xxx"> select < include refid="Base_Column_List"/> from xxx where del_flag=0 < choose > < when test="xxx !=null and xxx != ''"> and xxx like concat(concat('%', #{xxx}), '%') </ when > < otherwise > and xxx like '**%' </ otherwise > </ choose > </ select > |
下面就是MyBatis中的if....else...表示方法
1 2 3 4 5 6 7 8 | < choose > < when test=""> //... </ when > < otherwise > //... </ otherwise > </ choose > |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· Open-Sora 2.0 重磅开源!