在springboot中使用mybatis返回map类型数据空值字段不显示
时间: 2025-06-23 21:24:58 浏览: 11
### 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());
```
阅读全文
相关推荐


















