mybatisplus之Wrappers.ne踩坑记录解决

 更新时间:2023年05月09日 09:48:09   作者:data_too_long  
这篇文章主要为大家介绍了mybatisplus之Wrappers.ne踩坑记录解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一段看似平平无奇的代码

Classroom classroom = this.getOne(  
Wrappers.<Classroom>lambdaQuery()  
.select(Classroom::getId, Classroom::getJoinType)  
.eq(Classroom::getClassId, signupSubmitVO.getClassId())  
.eq(Classroom::getUserId, userId)  
);  
if (joinType == null && classroom != null) {  
joinType = classroom.getJoinType();  
}  
List<Classroom> hasClassroomList = this.list(  
Wrappers.<Classroom>lambdaQuery()  
.select(Classroom::getId, Classroom::getProvinceId, Classroom::getCityId, Classroom::getAreaId)  
.eq(Classroom::getClassId, signupSubmitVO.getClassId())  
.ne(classroom != null, Classroom::getId, classroom.getId())  //空指针
);

在测试过程中发生了预期之外的异常,在 .ne(signup != null, YySignup::getId, signup.getId())处报了空指针 在编写这个逻辑的时候,就预料到了classroom可能为null,所以才用了ne(boolean condition, R column, Object val)这个方法

按照我理解的逻辑当condition为false也就是classroom为null时,后面的条件就不会触发,自然classroom.getId()就不会执行,那自然就不会出现空指针异常。

报了异常

但实际它还是报了异常,再认真看了文档,关于condition的说明

boolean condition:表示该条件是否加入最后生成的sql中

也就是说condition只影响.ne( Classroom::getId, classroom.getId())这个条件是否加入最后生成的sql,并不会影响classroom.getId()的执行

以为它不会执行后面的操作纯属自己“一厢情愿、自作多情”

在mybatis关于ne的源码中第二个参数是一个Object类型的参数

default Children ne(R column, Object val) {
    return this.ne(true, column, val);
}

而上述代码中传入的是classroom.getId(),方法在执行过程中需要将这个表达式转换成具体的值,也就是执行classroom.getId(),而此时classroom为null,自然就报空指针了。

将classroom是否为null单独拿出来判断

为了规避这个问题,应该需要将classroom是否为null单独拿出来判断

Classroom classroom = this.getOne(
      Wrappers.<Classroom>lambdaQuery()
            .select(Classroom::getId, Classroom::getJoinType)
            .eq(Classroom::getClassId, signupSubmitVO.getClassId())
            .eq(Classroom::getUserId, userId)
);
if (joinType == null && classroom != null) {
   joinType = classroom.getJoinType();
}
LambdaQueryWrapper<Classroom> query = Wrappers.<Classroom>lambdaQuery()
      .select(Classroom::getId, Classroom::getProvinceId, Classroom::getCityId, Classroom::getAreaId)
      .eq(Classroom::getClassId, signupSubmitVO.getClassId())
if (classroom != null) {
   query.ne(Classroom::getId, classroom.getId());
}

虽然麻烦了一点点,但规避了问题。

以上就是mybatisplus之Wrappers.ne踩坑记录解决的详细内容,更多关于mybatisplus Wrappers.ne踩坑的资料请关注脚本之家其它相关文章!

相关文章

  • Netty分布式高性能工具类异线程下回收对象解析

    Netty分布式高性能工具类异线程下回收对象解析

    这篇文章主要介绍了Netty分布式高性能工具类异线程下回收对象解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • Spring Boot2发布调用REST服务实现方法

    Spring Boot2发布调用REST服务实现方法

    这篇文章主要介绍了Spring Boot2发布调用REST服务实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Java多线程阻塞与唤醒代码示例

    Java多线程阻塞与唤醒代码示例

    本文主要向大家分享了Java多线程中的阻塞与唤醒的相关内容,通过这篇文章大家可以大致了解到进入线程阻塞状态和可执行状态的方法,需要的朋友可以了解下。
    2017-09-09
  • Java之数组在指定位置插入元素实现

    Java之数组在指定位置插入元素实现

    本文主要介绍了Java之数组在指定位置插入元素实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Java获取Prometheus监控数据的方法实现

    Java获取Prometheus监控数据的方法实现

    本文主要介绍了Java获取Prometheus监控数据的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • Java布隆过滤器的应用实例

    Java布隆过滤器的应用实例

    这篇文章主要介绍了Java布隆过滤器的应用实例,在程序的世界中,布隆过滤器是程序员的一把利器,利用它可以快速地解决项目中一些比较棘手的问题,如网页 URL 去重、垃圾邮件识别、大集合中重复元素的判断和缓存穿透等问题,需要的朋友可以参考下
    2023-11-11
  • Java split()方法中的特殊符号举例详解

    Java split()方法中的特殊符号举例详解

    Java中的split方法可以将一个字符串按照指定的分隔符进行分割,返回一个字符串数组,这篇文章主要给大家介绍了关于Java split()方法中的特殊符号的相关资料,需要的朋友可以参考下
    2023-07-07
  • Java稀疏数组的应用实践

    Java稀疏数组的应用实践

    本文主要介绍了Java稀疏数组的应用实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • SpringBoot Web开发之系统任务启动与路径映射和框架整合

    SpringBoot Web开发之系统任务启动与路径映射和框架整合

    这篇文章主要介绍了SpringBoot Web开发中的系统任务启动与路径映射和Servlet、Filter、Listener框架整合,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • FluentMybatis实现mybatis动态sql拼装和fluent api语法

    FluentMybatis实现mybatis动态sql拼装和fluent api语法

    本文主要介绍了FluentMybatis实现mybatis动态sql拼装和fluent api语法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08

最新评论