mybatis test标签如何判断值是否相等
mybatis test标签判断值是否相等
mybatis可以很方便生成动态sql,
常用的方式如下:
<if test="id != null and id !=''"> and id != #{id} </if>
但是在实际使用过程中可能会需要对某个输入的值做具体判断,然后根据输入参数的值进行分支处理
<select id="xxxx" parameterType="map" resultMap="BaseResultMap"> 。。。。。。。 <choose> <when test="hasAttach.toString() == '1'.toString()"> having attachCount >= #{hasAttach} </when> <otherwise> having attachCount = #{hasAttach} </otherwise> </choose>
鉴于这个mapper查询接口传入的参数为Map<String,Object>类型,如果不进行toString的转换的话默认是对进行进行的对比,因此就无法达到预期的比较字符串的效果。
mybatis if test标签、动态sql问题
之前用#{0}和#{1}虽然值能传到后台但一直不能正确校验,怎么改都无法校验成功。
错误代码:
这是因为:dao层(或mapper层)中没有用@Param(“”)正确传值。
修改后:
mybatis中也把0,1改成@Paran定义的值就可以了:
体验:细节很重要,不可忽略。
做毕设,为这个问题纠结两天,网上没有人提到这一点,耽误很久,以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Spring Boot与Kotlin定时任务的示例(Scheduling Tasks)
这篇文章主要介绍了Spring Boot与Kotlin定时任务的示例(Scheduling Tasks),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-03-03Mybatis-plus更新字段为null两种常用方法及优化
Mybatis Plus在进行更新操作时,默认情况下是不能将字段更新为null的,如果要更新字段为null,需要进行以下处理,这篇文章主要给大家介绍了关于Mybatis-plus更新字段为null的两种常用方法及优化,需要的朋友可以参考下2024-03-03SpringBoot如何基于POI-tl和word模板导出庞大的Word文件
这篇文章主要介绍了SpringBoot如何基于POI-tl和word模板导出庞大的Word文件,poi-tl是一个基于Apache POI的Word模板引擎,也是一个免费开源的Java类库2022-08-08
最新评论