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

 更新时间:2022年03月12日 10:10:06   作者:xinyuezitang  
这篇文章主要介绍了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层 —> 对应xml 文件

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

Controller层请求参数keyword请求参数默认值Dao层Xml 文件
@RequestParam(value = “keyword”, required = false) String keywordnullif 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>

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Mybatis逆向生成使用扩展类的实例代码详解

    Mybatis逆向生成使用扩展类的实例代码详解

    这篇文章主要介绍了Mybatis逆向生成使用扩展类的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-05-05
  • Java跨域问题的处理详解

    Java跨域问题的处理详解

    这篇文章主要给大家介绍了关于Java跨域问题处理的相关资料,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • Win10 Java jdk14.0.2安装及环境变量配置详细教程

    Win10 Java jdk14.0.2安装及环境变量配置详细教程

    这篇文章主要介绍了Win10 Java jdk14.0.2安装及环境变量配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Java中MD5的使用代码示例

    Java中MD5的使用代码示例

    这篇文章主要给大家介绍了关于Java中MD5的使用示例,MD5加密是一种常见的加密方式,我们经常用在保存用户密码和关键信息上,需要的朋友可以参考下
    2023-08-08
  • Java由浅入深带你精通继承super

    Java由浅入深带你精通继承super

    继承就是子类继承父类的特征和行为,使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具有父类相同的行为
    2022-03-03
  • 一文详解Java中的动态填充Html模版并转PDF

    一文详解Java中的动态填充Html模版并转PDF

    在后端技术中,模板引擎和PDF生成工具是两个非常重要的领域,Thymeleaf和wkhtmltopdf是这两个领域的杰出代表,下面就来详细介绍一下Thymeleaf和wkhtmltopdf的技术特点吧
    2023-12-12
  • SpringBoot Starter机制及整合tomcat的实现详解

    SpringBoot Starter机制及整合tomcat的实现详解

    这篇文章主要介绍了SpringBoot Starter机制及整合tomcat的实现,我们知道SpringBoot自己在“后台”帮我们配置了很多原本需要我们手动去的东西,至于这个“后台”是啥,就是Starter机制
    2022-09-09
  • Java事件处理步骤讲解

    Java事件处理步骤讲解

    今天小编就为大家分享一篇关于Java事件处理步骤讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • Java8深入学习系列(二)函数式编程

    Java8深入学习系列(二)函数式编程

    函数式编程,这个词语由两个名词构成,函数,编程。编程这个词我就不用解释了,大家都是做这个的。函数,其实单独抽离出来这个词语,也并不陌生,那二者组合后的到底是什么呢,下面这篇文章主要给大家介绍了关于Java8函数式编程的相关资料,需要的朋友可以参考下。
    2017-08-08
  • Spring XML Schema扩展机制的使用示例

    Spring XML Schema扩展机制的使用示例

    所谓整合,即在Spring的框架下进行扩展,让框架能无缝的与Spring工程配合使用。Spring设计了良好的扩展的机制,本文将对Spring的扩展方法及原理进行简单介绍。
    2021-05-05

最新评论