MyBatis——案例——查询-单条件查询-动态条件查询

风陵南·2022-09-26 00:41·47 次阅读

MyBatis——案例——查询-单条件查询-动态条件查询

单条件查询-动态条件查询(choose(when,otherwise))

  

  从多个条件中选择一个

  choose(when,otherwise) 选择,类似于java中的Switch语句(when 相当于 case  otherwise 相当于 default)

<!-- 单条件查询-动态查询 -->
<select id="selectByConditionSingle" resultMap="brandResultMap">
select * from tb_brand
where
<choose>
<when test="status != null">
status = #{status}
</when>
<when test="companyName != null and companyName != ''">
company_name like #{companyName}
</when>
<when test="brandName != null and brandName != ''">
brand_name like #{brand_name}
</when>
<otherwise>
1 = 1
</otherwise>
</choose>
</select>

  默认条件使用otherwise是不太方便的,可以使用上一节的 where标签即可

<!-- 单条件查询-动态查询 -->
<select id="selectByConditionSingle" resultMap="brandResultMap">
select * from tb_brand
<where>
<choose>
<when test="status != null">
status = #{status}
</when>
<when test="companyName != null and companyName != ''">
company_name like #{companyName}
</when>
<when test="brandName != null and brandName != ''">
brand_name like #{brand_name}
</when>
</choose>
</where>
</select>

 

posted @   风陵南  阅读(47)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示