Mybatis中isNotNull与isNotEmpty的使用心得

 更新时间:2022年03月10日 10:04:03   作者:春秋战国程序猿  
这篇文章主要介绍了Mybatis中isNotNull与isNotEmpty的使用心得,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

isNotNull与isNotEmpty使用心得

做开发工作时间长了,会发现,在需求逐步梳理清晰以后,大致的方向已经明确了。此时会进入细节开发环节,是最繁琐,也是决定开发质量的关键阶段。最近遇到了一个生产问题,必填字段的值,清空保存,无法保存成功。

具体业务需求是这样的

客户的基本信息,坐席可以保存,也可以提交后端系统进行审批。

1,保存的时候,其实就是一个暂存的功能,只要坐席输入的是合法的值,都要保存入库。

2,提交审批的时候会进行各种校验,包括合法性校验、必填校验,业务逻辑校验等等。

生产问题就出在这个保存的功能上,如果一个字段有值,但是坐席清空,点保存,这时候保存没有生效。

问题其实也很好定位,我去看了一下代码就找到问题了。但是这个问题在生产上一直存在的。

主要是不是阻断性问题,影响不大,所以可能有的坐席发现了,也没有在意,没有报生产问题。

原因就是:本该使用isNotNull的地方,缺使用了isNotEmpty

以上是从业务的角度来分析的,接下来,我们从技术角度来看一下这个问题。

  • isNotNull,顾名思义,就是不为null,也就是<>null
  • isNotEmpty,顾名思义就是不为空,也就是<>null,并且<>''(空字符串)

区别也很明显,就是是否包含空字符串。针对上面的业务场景,我们需要保存空字符串,该什么哪个呢

看一下下面2个SQL语句

UPDATE
    PRODUCT P
SET
    UPDATE_TIME = SYSDATE
    <isNotEmpty prepend="AND" property="productName">
        P.PRODUCT_NAME = #productName#
    </isNotEmpty>
WHERE
    P.PRODUCT_ID = #productId#
UPDATE
    PRODUCT P
SET
    UPDATE_TIME = SYSDATE
    <isNotNull prepend="AND" property="productName">
        P.PRODUCT_NAME = #productName#
    </isNotNull>
WHERE
    P.PRODUCT_ID = #productId#

当页面传递过来的值为空字符串时,我们要保证能执行对PRODUCT_NAME的修改,很显然,需要使用isNotNull标签。

出问题的原因其实也简单,就是复制粘贴的代码,也没有注意到isNotNull与isNotEmpty的区别。

所以平时我们还是要细心,关键心中要有分寸,如果你很清楚的知道isNotNull与isNotEmpty的区别,一旦看到这个,你自然就会想到该如何使用。

isNull, isNotNull与isEmpty, isNotEmpty区别

关于这个看了很多例子都很模糊

  • 在iBATIS中isNull用于判断参数是否为Null,isNotNull相反
  • isEmpty判断参数是否为Null或者空,满足其中一个条件则其true
  • isNotEmpty相反,当参数既不为Null也不为空是其为true

例子

  <update id="updateYbAndSb" parameterClass="java.util.HashMap">
    UPDATE MZSF_CLININVOINFO T
    <dynamic prepend="SET">
      <isNotNull property="YBZHCODE">
       <isEmpty property="YBZHCODE" prepend=","> T.YBZHCODE = NULL</isEmpty>
       <isNotEmpty property="YBZHCODE" prepend=","> T.YBZHCODE = #YBZHCODE#</isNotEmpty>
      </isNotNull>
      <isNotNull property="HOSPID">
       <isEmpty property="HOSPID" prepend=","> T.HOSPID = NULL</isEmpty>
       <isNotEmpty property="HOSPID" prepend=","> T.HOSPID = #HOSPID#</isNotEmpty>
      </isNotNull>
      <isNotNull property="SBZFJE">
       <isEmpty property="SBZFJE" prepend=","> T.SBZFJE = NULL</isEmpty>
       <isNotEmpty property="SBZFJE" prepend=","> T.SBZFJE = #SBZFJE#</isNotEmpty>
      </isNotNull>
      <isNotNull property="SBZFXJJE">
       <isEmpty property="SBZFXJJE" prepend=","> T.SBZFXJJE = NULL</isEmpty>
       <isNotEmpty property="SBZFXJJE" prepend=","> T.SBZFXJJE = #SBZFXJJE#</isNotEmpty>
      </isNotNull>
    </dynamic>      
   WHERE T.SFID = #SFID#
     AND T.FORGID = #FORGID#    
   </update>

上面sql语句,如果 YBZHCODE传入的是null 即:

hashMap.put("YBZHCODE",null);    

则sql语句中不会更新这个字段

如果YBZHCODE传入的是空 即:

hashMap.put("YBZHCODE",“”);    

则sql语句 会将这个字段更新成null,为空

如果有值,则更新成传入的值

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

相关文章

  • Redis中String字符串和sdshdr结构体超详细讲解

    Redis中String字符串和sdshdr结构体超详细讲解

    这篇文章主要介绍了Redis中String字符串和sdshdr结构体,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-04-04
  • Java中操作超大数的方法

    Java中操作超大数的方法

    本篇文章是小编在网上整理的关于java操作超大数的方法以及解决思路,有兴趣的朋友参考学习下。
    2018-06-06
  • 详解 Java继承关系下的构造方法调用

    详解 Java继承关系下的构造方法调用

    这篇文章主要介绍了详解 Java继承关系下的构造方法调用的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下
    2017-10-10
  • idea中Maven镜像源详细配置步骤记录(对所有项目)

    idea中Maven镜像源详细配置步骤记录(对所有项目)

    Maven是一个能使我们的java程序开发节省时间和精力,是开发变得相对简单,还能使开发规范化的工具,下面这篇文章主要给大家介绍了关于idea中Maven镜像源详细配置(对所有项目)的相关资料,需要的朋友可以参考下
    2023-05-05
  • SpringBoot入门编写第一个程序Helloworld

    SpringBoot入门编写第一个程序Helloworld

    这篇文章是Springboot入门篇,来教大家编写第一个Springboot程序Helloworld,文中附有详细的示例代码,有需要的同学可以借鉴参考下
    2021-09-09
  • SpringBoot中使用 RabbitMQ的教程详解

    SpringBoot中使用 RabbitMQ的教程详解

    这篇文章主要介绍了SpringBoot中使用 RabbitMQ的教程详解,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • jmeter设置全局变量与正则表达式提取器过程图解

    jmeter设置全局变量与正则表达式提取器过程图解

    这篇文章主要介绍了jmeter设置全局变量与正则表达式提取器过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • java实现水仙花数的计算

    java实现水仙花数的计算

    这篇文章主要为大家详细介绍了java实现水仙花数的计算,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Java并发Map面试线程安全数据结构全面分析

    Java并发Map面试线程安全数据结构全面分析

    本文将探讨如何在Java中有效地应对这些挑战,介绍一种强大的工具并发Map,它能够帮助您管理多线程环境下的共享数据,确保数据的一致性和高性能,深入了解Java中的并发Map实现,包括ConcurrentHashMap和ConcurrentSkipListMap,及相关知识点
    2023-09-09
  • Mybatis中注入执行sql查询、更新、新增及建表语句案例代码

    Mybatis中注入执行sql查询、更新、新增及建表语句案例代码

    这篇文章主要介绍了Mybatis中注入执行sql查询、更新、新增以及建表语句,主要说明一个另类的操作,注入sql,并使用mybatis执行,结合案例代码详解讲解,需要的朋友可以参考下
    2023-02-02

最新评论