解决mybatis返回boolean值时数据库返回null的问题

 更新时间:2020年11月25日 09:25:50   作者:lw1242189467  
这篇文章主要介绍了解决mybatis返回boolean值时数据库返回null的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

常规情况,我们使用数据库判断 true or false。所写的语句是select count(id) from 表名;

这种常用情况下,只有当查询语句查到数据 且 只有一条时才会返回 true;

还有一种情况,就是数据库中返回判断句,比如

返回的对错将以1或0表示;

但是当返回值为null,或者多个值的时候 会怎么样呢,0 1 还是报错?

测试表示这种情况下会报错:

希望大家使用 boolean 返回时 也能格外小心。

这里简单做了更改方法,可能不是最优化的,有更好的意见还请不吝赐教。

补充知识:mybatis mapper方法返回值是null还是空对象,或者空列表?

返回单个实体对象,从数据库中没有查到数据时返回为null;

返回Map类型数据,从数据库中没有查到数据时返回为一个空map(size==0),内部用反射创建的HashMap对象,有数据时放入这个map,没数据就直接返回这个没有任何元素的map,而不是null;

返回List类型数据,从数据库中没有查到数据时返回为一个空列表(size==0),内部返回的是自己new的List,有元素则添加进去,没元素就返回这个list,不会为null。

myabtis源代码在MapperMethod类下的这段代码,分别追查下去就行了。。我跟踪之后得到的结果就是上面这些,当然,只是跟踪了一部分的实现类,可能其他实现类是不这样呢?如果有误请评论。。等先研究一下spring源码之后再仔细看看mybatis源码。

以上这篇解决mybatis返回boolean值时数据库返回null的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Linux下JDK安装教程

    Linux下JDK安装教程

    这篇文章主要为大家详细介绍了Linux下JDK安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 如何用Springboot Admin监控你的微服务应用

    如何用Springboot Admin监控你的微服务应用

    这篇文章主要介绍了如何用Springboot Admin监控你的微服务应用,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下。
    2021-01-01
  • JAVA实现深拷贝的几种方式代码

    JAVA实现深拷贝的几种方式代码

    这篇文章主要给大家介绍了关于JAVA实现深拷贝的几种方式,在Java中深拷贝和浅拷贝是用来复制对象的两种不同方式,深拷贝会对所有数据类型进行拷贝,包括对象所包含的内部对象,需要的朋友可以参考下
    2023-09-09
  • Java实现对两个List快速去重并排序操作示例

    Java实现对两个List快速去重并排序操作示例

    这篇文章主要介绍了Java实现对两个List快速去重并排序操作,结合实例形式较为详细的分析了Java针对list的遍历、去重、排序相关操作技巧与注意事项,需要的朋友可以参考下
    2018-07-07
  • Swagger实现动态条件注入与全局拦截功能详细流程

    Swagger实现动态条件注入与全局拦截功能详细流程

    这篇文章主要介绍了Swagger实现动态条件注入与全局拦截功能详细流程,Swagger 可以提供 API 操作的测试文档,本文记录 Swagger 使用过程中遇到的小问题
    2023-01-01
  • java实现将域名解析成ip示例

    java实现将域名解析成ip示例

    这篇文章主要介绍了java实现将域名解析成ip示例,需要的朋友可以参考下
    2014-04-04
  • Mybatis-Plus自动生成代码的实现示例

    Mybatis-Plus自动生成代码的实现示例

    在工作中,程序员很多时候都是在写类似的代码,可以使用自动生成代码,本文主要介绍了Mybatis-Plus自动生成代码的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • java ConcurrentHashMap分段加锁提高并发效率

    java ConcurrentHashMap分段加锁提高并发效率

    这篇文章主要为大家介绍了java ConcurrentHashMap分段加锁提高并发效率,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • Java中String字符串常量池和intern方法源码分析

    Java中String字符串常量池和intern方法源码分析

    在之前的文章中,小编给大家介绍了String字符串的不可变性及其实现原理,其中给大家提到了字符串常量池的概念,那么什么是常量池,String字符串与常量池有什么关系,本文给大家唠唠字符串常量池及String#intern()方法的作用,需要的朋友可以参考下
    2023-05-05
  • 简单了解Java的默认和静态方法

    简单了解Java的默认和静态方法

    这篇文章主要介绍了简单了解Java的默认和静态方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01

最新评论