解决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的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
浅谈mybatis中SQL语句给boolean类型赋值问题
我就废话不多说了,大家还是直接看代码吧~ <select id="getBiTree" parameterType="String" resultMap="MenuVoListMap"> SELECT m.menu_id , m.parent_id , m.`name` , 1 opens FROM menu m WHERE m.is_valid = 1 AND (m.type = 0 or m.type = 1) and m.men
-
解决MyBatis返回结果类型为Boolean的问题
问题描述: 在使用MyBatis时,有时需要检查某个记录是否存在数据库中,然后根据其返回的布尔值true or false,来进行逻辑判断.那怎么做呢? 解决方案: 如检测某个手机号是否被注册过: <select id="checkPhoneExist" parameterType="java.lang.String" resultType="java.lang.Boolean"> <![CDATA[ select count(
-
MyBatis查询结果resultType返回值类型的说明
一.返回一般数据类型 比如要根据 id 属性获得数据库中的某个字段值. mapper 接口: // 根据 id 获得数据库中的 username 字段的值 String getEmpNameById(Integer id); SQL 映射文件: <!-- 指定 resultType 返回值类型时 String 类型的, string 在这里是一个别名,代表的是 java.lang.String 对于引用数据类型,都是将大写字母转小写,比如 HashMap 对应的别名是 'hashmap' 基本数
-
解决mybatis返回boolean值时数据库返回null的问题
常规情况,我们使用数据库判断 true or false.所写的语句是select count(id) from 表名: 这种常用情况下,只有当查询语句查到数据 且 只有一条时才会返回 true; 还有一种情况,就是数据库中返回判断句,比如 返回的对错将以1或0表示: 但是当返回值为null,或者多个值的时候 会怎么样呢,0 1 还是报错? 测试表示这种情况下会报错: 希望大家使用 boolean 返回时 也能格外小心. 这里简单做了更改方法,可能不是最优化的,有更好的意见还请不吝赐教. 补充知
-
解决mybatis执行SQL语句部分参数返回NULL问题
今天在写代码的时候发现一个问题:mybatis执行sql语句的时候返回bean的部分属性为null,在数据库中执行该sql语句能够正常返回,把相关代码反反复复翻了个遍,甚至都重启eclipse了,依旧没解决问题,后来网上搜了一下,还真有类似的问题. 闲话少说,直接说问题,该sql语句是自己写的,resultType直接用了该bean全名称,最终导致部分属性显示为null, 原来的写法: <select id="selectByArticle" parametertype=&quo
-
MyBatis查询无记录时的返回值问题
目录 MyBatis查询无记录的返回值 在MyBatis 3.4.1下 查询无结果时的返回值报错问题 mybatis的查询无结果时报错 MyBatis查询无记录的返回值 在MyBatis 3.4.1下 如果Dao的返回值是实体,则select查询无记录时返回null.容易报空指针异常! Notice findById(); 如果Dao的返回值是List,则select查询无记录是返回的是[],也就是空数组, 而不是null.所以这时候判空需要用CollectionUtils.isNotEmpty
-
解决mybatis一对多查询resultMap只返回了一条记录问题
问题描述:因为领导的一个需求,需要用到使用resultMap,很久没使用了,结果就除了点意外.就记录下这个问题 准备两个类:author(作者)和book(书),数据库创建对应的author->book一对多的数据 @Data public class Author { private Integer id; private String name; private String phone; private String address; private List<Book> book
-
浅谈Java中的this作为返回值时返回的是什么
有时会遇到this作为返回值的情况,那么此时返回的到底是什么呢? 返回的是调用this所处方法的那个对象的引用,读起来有点绕口哈,有没有想起小学语文分析句子成份的试题,哈哈. 一点点分析的话,主干是"返回的是引用": 什么引用呢?"那个对象的引用": 哪个对象呢?"调用方法的那个对象": 调用的哪个方法呢?"调用的是this所位于的方法":这样就清楚了. 再总结一下就是,this作为返回值时,返回的是调用某方法的对象的引用,这
-
解决mybatis使用char类型字段查询oracle数据库时结果返回null问题
同事在学mybatis时,遇到了一个问题就是,使用char类型字段作为查询条件时一直都查不出数据,其他类型的则可以. 使用的数据库是oracle,查询条件字段类型是char(50),java代码对应的是String类型. 后来经过排查,是由于在oracle中,char类型字段,如果内容长度不够,会自动以空格方式补足长度.如字段 name char(5),若值为sgl,那么oracle会自动用空格补足长度,最终值为sgl. 一.解决方法: 方法1:先用trim()函数把值去掉两边空格再作为条件查询
-
mybatis中查询结果为空时不同返回类型对应返回值问题
今天在别人的代码基础上实现新需求,看到对于mybatis查询结果的判断不是很正确,如果查询结果为空就会异常,不知道大家有没有这样的疑惑:mybatis中resultType有多种返回类型,对于每种不同类型,查询结果为空时dao接口的返回值是一样的吗?接下来我就总结一下常见的几种情况. 第一种:resultType为基本类型,如string(在此暂且把string归纳为基本类型) 如果select的结果为空,则dao接口返回结果为null 第二种,resultType为基本类型,如int 后台报异
-
解决Mybatis中mapper.xml文件update,delete及insert返回值问题
最近写了几个非常简单的接口(CRUD),在单元测试的时候却出了问题,报错如下: Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'messageListener': Unsatisfied dependency expressed through field 'reviewCheckInfoService'; nested exce
-
mybatis的insert语句插入数据时的返回值的实现
mybatis的sql语句一般是配置在配置文件中,现先给出一个例子, sqlMap.xml文件中的一条插入语句: <insert id="add" parameterClass="xxx"> insert into A(a, b, c, d) VALUE (#a#, #b#, #c#, #d#) </insert> 以上的代码片段只是最简单的插入语句,上面这条SQL语句无论执行结果是成功还是失败,它的返回值都是null 如果想要在执行插入之后
随机推荐
- JavaScript中Boolean对象的属性解析
- cmd下开启telnet的方法
- mysql 5.7.13 安装配置笔记(Mac os)
- 用JQuery 实现的自定义对话框
- 在jsp中用bean和servlet联合实现用户注册、登录
- 输入gpedit.msc后提示找不到gpedit.msc的解决方法
- Python3中多线程编程的队列运作示例
- ASP.NET书籍信息录入实现代码
- thinkPHP简单遍历数组方法分析
- php提示undefined index的几种解决方法
- 关于数据库设计中主键问题的思考
- auto病毒引发木马下载者病毒的完美解决方案 原创
- JavaScript中的this关键字使用详解
- Java单例模式简单示例
- Java开发中读取XML与properties配置文件的方法
- PHP的开发框架的现状和展望
- 改进性能和样式的24个ASP 技巧
- 比较discuz和ecshop的截取字符串函数php版
- 按上下级层次关系输出内容的PHP代码
- SQL Server误区30日谈 第3天 即时文件初始化特性可以在SQL Server中开启和关闭