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踩坑的资料请关注脚本之家其它相关文章!

相关文章

  • Java NIO下ByteBuffer的常用方法学习

    Java NIO下ByteBuffer的常用方法学习

    这篇文章主要带大家来初步学习一下NIO 中的 ByteBuffer的应用与常用方法,文中的示例代码讲解详细,对我们深入学习Java有一定的帮助,感兴趣的可以了解一下
    2023-05-05
  • springboot中使用雪花算法生成雪花ID

    springboot中使用雪花算法生成雪花ID

    本文主要介绍了springboot中使用雪花算法生成雪花ID,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • SpringBoot整合Keycloak实现单点登录的示例代码

    SpringBoot整合Keycloak实现单点登录的示例代码

    本文主要介绍了SpringBoot整合Keycloak实现单点登录的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Mybatis接口Mapper内的方法为啥不能重载吗

    Mybatis接口Mapper内的方法为啥不能重载吗

    这篇文章主要介绍了Mybatis接口Mapper内的方法为啥不能重载吗,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 详解Java获取环境变量及系统属性的方法

    详解Java获取环境变量及系统属性的方法

    这篇文章主要介绍了详解Java获取环境变量及系统属性的方法,讲解了System.getEnv()和System.getProperties()这两个核心方法的使用,需要的朋友可以参考下
    2016-05-05
  • 关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s)

    关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out afte

    这篇文章主要介绍了Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s),本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2021-03-03
  • springboot2中使用@JsonFormat注解不生效的解决

    springboot2中使用@JsonFormat注解不生效的解决

    这篇文章主要介绍了springboot2中使用@JsonFormat注解不生效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 基于java实现简单的银行管理系统

    基于java实现简单的银行管理系统

    这篇文章主要介绍了基于java实现简单的银行管理系统,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • Java学习之缓冲流的原理详解

    Java学习之缓冲流的原理详解

    为了提高其数据的读写效率,Java中又定义了四种缓冲流,分别是:字节缓冲输入流、字节缓冲输出流、字符缓冲输入流和字符缓冲输出流。本文主要来和大家聊聊这些缓冲流的原理,希望对大家有所帮助
    2023-01-01
  • JAVA如何把数据库的数据处理成树形结构

    JAVA如何把数据库的数据处理成树形结构

    本文介绍了JAVA如何把数据库的数据处理成树形结构,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论