欢迎光临
我们一直在努力

mybatis if test不为空字符串且不为null的问题怎么解决

这篇文章主要介绍“mybatis if test不为空字符串且不为null的问题怎么解决”,在日常操作中,相信很多人在mybatis if test不为空字符串且不为null的问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mybatis if test不为空字符串且不为null的问题怎么解决”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

if test不为空字符串且不为null

在mybatis中if test 

判断不为空字串和null的时候,报了sql 语法错误

xml文件:

WHERE enable =1
<if test="keyword != null AND keyword != ''">
        AND ( mac_id = #{keyword} )
        OR ( user_id = #{keyword} )
 </if>

postman工具报错如下:

原因:

if 判断中, 出现字母大小写错误, 不符合mybatis 语法规范

在mybatis中, if test 语法

1 判断不为null

WHERE 1=1
<if test="keyword != null ">
        AND  user_id = #{keyword} 
</if>

2 判断不为空字符串

WHERE 1=1
<if test="keyword != '' ">
        AND  user_id = #{keyword} 
</if>

3 判断不为null 且 不为空字符串

WHERE 1=1
<if test="keyword != null and keyword != ''">
        AND  user_id = #{keyword} 
</if>

Controller层 &mdash;> 对应xml 文件

我们在获取列表时,通常会根据关键词进行精确或模糊查询,就会对关键词进行非空或者非null的判断。如下:

Controller层请求参数keyword 请求参数默认值 Dao层Xml 文件
@RequestParam(value = “keyword”, required = false) String keyword null if test="keyword != null "
@RequestParam(value = “keyword”, required = false, defaultValue = “”) String keyword 空字符串 if test="keyword != &lsquo;&rsquo; "
/ 不清楚默认值 都可以if test=“keyword != null and keyword != &lsquo;&rsquo;”
参数 默认值 Dao层Xml 文件
从其他渠道的获取的数据或关键词 不清楚默认值 if test=“keyword != null and keyword != &lsquo;&rsquo;”

mybatis把0当做空字符串

在开发中,一般在sqlmap中都会判断参数是否为null,以及是否为空字符串

当参数为Int类型 0时,myBatis自动把0定义为空字符串“”

我们在可能入参为0的地方多加一个判断

 <if test="authorizeAmount != null and ''!= authorizeAmount or authorizeAmount==0">
            ,a.AUTHORIZE_AMOUNT = #{authorizeAmount,jdbcType=VARCHAR}
        </if>

到此,关于“mybatis if test不为空字符串且不为null的问题怎么解决”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云搜网网站,小编会继续努力为大家带来更多实用的文章!

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。