6 MyBatis动态SQL之choose(when、otherwise)语句
1 MyBatis动态SQL之if 语句
2 MyBatis动态sql之where标签|转
3 MyBatis动态SQL之set标签|转
4 MyBatis动态SQL之trim元素|转
5 MyBatis动态sql中foreach标签的使用
6 MyBatis动态SQL之choose(when、otherwise)语句
7 MyBatis动态SQL之bind标签|转
有时候,我们不想用所有的条件语句,而只想从中择其一二。针对这种情况,MyBatis提供了choose元素,它有点像Java中的switch语句。还是上面的例子,但是策略变为:传入了 id就按id查找,传入了loginname 和password就按loginnam 和password查找,若两者都没有提供,就返回所有sex等于男的Employee。
<select id="selectEmployeeChoose" parameterType="hashmap" resultType="my.mybatis.domain.Employee">
SELECT * FROM tb employee WHERE state = 'ACTIVE'
<!--- 如果传入了id,就根据id查询,没有传入id就根据loginname和password查询,否则查询sex等于男的数据-->
<choose>
<when test="id != null">
and id= #{id}
</when>
<when test="loginname != null and password != null">
loginname = #{loginname} and password = #{password}
and
</when>
<otherwise>
and sex = '男'
</otherwise>
</choose>
</select>
提供id、loginname 和password的时候,调用selectEmployeeChoose()方法,控制台显示如下:
SELECT * FROM tb_employee WHERE state = 'ACTIVE' and loginname = ? and password = ?
由于传递的参数只包括loginname和password,所以sql语句是按照loginname和password查找,查询返回的Emplyee对象就是loginname,即jack,并且password是123456的对象。没有传递任何参数时,控制台显示如下:
SELECT * FROM tb_employee WHERE state = 'ACTIVE' and sex = '男'
可以看到,由于没有传递任何参数,故sql语句执行的是< otherwise >元素里面的查询条"sex='男'"的对象。

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南