Mybatis中 list.size() = 1 但显示 All elements are null

一、Bug展示

二、原因分析

2.1.情形一:Mybatis的XML中返回类型映射错误

复制代码
<select id="selectByDesc" parameterType="com.task.bean.OrderInfo"
            resultType="com.task.bean.OrderInfo">
        select MER_ID,SETTLE_DATE,ICE_NAME,ORDER_STATUS,ORDER_CODE,ORDER_DESC,
        COUNT(*) AS SUM_COUNT,SUM(ORDER_AMT) AS SUM_AMT
        FROM order_info_${ny}
        <where>
            <if test="settleDate != null and settleDate != ''">
                AND SETTLE_DATE = #{settleDate}
            </if>
        </where>
        GROUP BY SETTLE_DATE
</select>

在此时,resultType中对应的是实体bean,但由于参数不完全对应或参数类型不完全匹配,造成查询到的数据不能正常返回。此时可以调整实体bean或修改xml,使字段完全对应;或者使用resultMap重新定义返回参数,示例如下:

复制代码
<resultMap id="orderInfo" type="com.task.bean.OrderInfo">
        <result property="orderId" column="ORDER_ID"/>
        <result property="merId" column="MER_ID"/>
        <result property="merName" column="MER_NAME"/>
 
        *  *  *  *  *  *  *  *  *  *  *  *  *  *  *
 
        <result property="sumCount" column="SUM_COUNT"/>
</resultMap>
 
 
 
 
<select id="selectByDesc" parameterType="com.task.bean.OrderInfo"
            resultMap="orderInfo">    
        select MER_ID,SETTLE_DATE,ICE_NAME,ORDER_STATUS,ORDER_CODE,ORDER_DESC,
        COUNT(*) AS SUM_COUNT,SUM(ORDER_AMT) AS SUM_AMT
        FROM order_info_${ny}
        <where>
            <if test="settleDate != null and settleDate != ''">
                AND SETTLE_DATE = #{settleDate}
            </if>
        </where>
        GROUP BY SETTLE_DATE
</select>

2.2.情形二:使用了MySQL中的聚合函数

在使用MySQL中的聚合函数,分别是求和函数SUM()、求平均函数AVG()、最大值函数MAX()、最小值函数MIN()和计数函数COUNT, 进而导致出现size = 1,但结果为空的情况。

此时无论是否数据库中是否有值 , 返回都不为空。通过上面debug步骤发现, list.size() = 1,但List中值为空, 显示All elements are null

此时在无法优化xml的情况下,可以调整业务层代码,例如:

复制代码
if (CollectionUtils.isNotEmpty(listData) && listData.get(0) != null) {
    
    *  *  *  *  *  *  *  *  *  *  *  *  *  *  *
 
}

手动将这种情况给排除掉。或者,先把list中的null元素给排除掉,然后在进行业务的数据处理

复制代码
//移除第一个null
 
list.remove(null); 
 
//或移除所有的null元素
 
list.removeAll(Collections.singleton(null)); 

三、聚合函数

Java 使用聚合函数查询时,返回的结果一定不为null的原因是聚合函数的定义决定了它们的行为。聚合函数用于对一组值进行计算,并返回一个结果。根据聚合函数的定义,它们总是返回一个非空的结果,即使输入为空或无效。这是为了确保计算的一致性和可靠性。

举个例子,如果你使用 SUM() 聚合函数计算一组数值的总和,即使输入为空,它也会返回0作为结果。同样地,如果你使用 AVG() 聚合函数计算一组数值的平均值,即使输入为空,它也会返回0作为结果。

因此,Java 使用聚合函数查询时,可以确保返回的结果一定不为null,而是根据聚合函数的定义返回一个合适的值。同样的,这也造成数据在一定情况下需要手动排查掉NULL的情况。

转自:Mybatis中 list.size() = 1 但显示 All elements are null_棒棒糖的糖不含糖的博客-CSDN博客

相关推荐
拼搏@1 小时前
第十六天,7月10日,八股
java·mybatis
军军君0110 小时前
基于Springboot+UniApp+Ai实现模拟面试小工具四:后端项目基础框架搭建下
spring boot·spring·面试·elementui·typescript·uni-app·mybatis
超级小忍13 小时前
在 Spring Boot 中使用 MyBatis 的 XML 文件编写 SQL 语句详解
xml·spring boot·mybatis
程序猿小D14 小时前
[附源码+数据库+毕业论文+答辩PPT+部署教程+配套软件]基于SpringBoot+MyBatis+MySQL+Maven+Vue实现的交流互动管理系统
spring boot·mysql·vue·mybatis·毕业论文·答辩ppt·交流互动
24kHT1 天前
xml映射文件的方式操作mybatis
xml·mybatis
栈溢出了2 天前
MyBatis实现分页查询-苍穹外卖笔记
java·笔记·mybatis
weixin_456904272 天前
Spring Boot整合MyBatis+MySQL+Redis单表CRUD教程
spring boot·mysql·mybatis
Cyanto2 天前
Spring注解IoC与JUnit整合实战
java·开发语言·spring·mybatis
gadiaola2 天前
【SSM面试篇】Spring、SpringMVC、SpringBoot、Mybatis高频八股汇总
java·spring boot·spring·面试·mybatis
Cyanto2 天前
深入MyBatis:CRUD操作与高级查询实战
java·数据库·mybatis