欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

mybatis if test 不为空字符串且不为null的问题

时间:2022-09-02 09:15:45|栏目:JAVA代码|点击:

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层 —> 对应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 != ‘’ "
/ 不清楚默认值 都可以if test=“keyword != null and keyword != ‘’”
参数 默认值 Dao层Xml 文件
从其他渠道的获取的数据或关键词 不清楚默认值 if test=“keyword != null and keyword != ‘’”

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>

这是一个比较容易粗心的地方,出问题也不容易排查,记录下来提醒自己!

上一篇:SpringBoot搭建多数据源的实现方法

栏    目:JAVA代码

下一篇:Java多线程之同步工具类CountDownLatch

本文标题:mybatis if test 不为空字符串且不为null的问题

本文地址:http://www.codeinn.net/misctech/212579.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有