mybatis 返回map,空值字段为null时配置,not showing null elements

博客指出使用MyBatis分页时返回结果异常,在debug模式下出现not showing null elements情况。用map接收结果时,含null元素的结果会丢失null元素。若要显示含null元素的结果,可通过XML配置CallSettersOnNulls和ReturnInstanceForEmptyRow来解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用mybatis的时候,分页返回结果很奇怪,使用debug模式出现了not showing null elements。

用map接收的时候,
{
“column1”:null,
“column2”:“123”
}
会变成
{
“column2”:“123”
}
想要第一种显示,需要配置::

   /**
     * mybatis 返回map,字段为null时配置
     * @return
     */
    public static Configuration mapForEmptyRowConfiguration(){
        Configuration config = new Configuration();
        config.setCallSettersOnNulls(true);
        config.setReturnInstanceForEmptyRow(true);
        return config;
    }

XML配置 CallSettersOnNulls ReturnInstanceForEmptyRow 即可。

### Spring Boot 中 MyBatis 返回 Map 类型数据处理空值字段 在 Spring Boot 应用程序中使用 MyBatis 进行数据库操作并返回 `Map` 类型的数据,默认情况下,对于查询结果中的空值字段不会显示。为了实现这一功能,在应用程序的配置文件 `application.properties` 或者 `application.yml` 文件中设置特定属性即可。 #### 配置方式 通过调整 MyBatis 的全局配置项来控制是否调用 Java Bean 属性设值方法即使参数为 null 也执行: ```properties mybatis.configuration.call-setters-on-nulls=false ``` 此配置意味着当查询的结果集中某个列对应的值为空MyBatis 将不会为此字段创建键值对条目于最终返回给用户的映射对象之中[^1]。 另外一种做法是在 XML 映射文件里指定 `<select>` 标签内的 `resultOrdered` 参数为 true 并配合自定义 resultMap 来过滤掉不需要展示出来的 NULL字段[^2]。 然而需要注意的是上述两种解决方案都依赖具体的框架版本以及项目结构设计;因此建议开发者依据实际开发环境选择最合适的办法去解决问题。 对于希望完全移除所有可能存在的空白记录的情况而言,可以在业务逻辑层面上做进一步处理,比如利用 Stream API 对 List<Map<String, Object>> 结果集进行筛选去除含有任何 key 关联 value 是 null 的 entry[]()。 ```java List<Map<String, Object>> resultList = ...; // 移除非有效(含null值)entry后的列表 List<Map<String, Object>> filteredResultList = resultList.stream() .map(map -> map.entrySet().stream() .filter(entry -> Objects.nonNull(entry.getValue())) .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue))) .collect(Collectors.toList()); ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值