Mybatis resultMap空值映射问题解决

本文介绍如何在MyBatis中处理查询结果中的空值字段,提供了通过配置设置及自定义类型处理器两种方法实现对空值字段的映射。

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

Mybatis在使用resultMap来映射查询结果中的列,如果查询结果中包含空值的列(不是null),则Mybatis在映射的时候,不会映射这个字段,例如 查询 name,sex,age,数据库中的age字段没有值,Mybatis返回的map中只映射了 name和sex字段,而age字段则没有包含。

那么如何将age字段映射到map中呢。提供两种解决方法:

使用Mybatis config配置

创建configuration.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD SQL MAP Config 3.1//EN" 
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  <settings>
      <setting name="callSettersOnNulls" value="true"/>
  </settings>
</configuration>

配置Mybatis的SqlSessionFactoryBean

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="configLocation" value="classpath:/META-INF/spring/configuration.    xml" />
    <property name="mapperLocations"
    value="classpath:/META-INF/spring/mybatis/modelMap/*.xml" />
</bean>

在这种配置中,age将以null值映射到map中。

如果想要配置age的默认值,则可以建立一个类,实现Mybatis的TypeHandler接口

public class EmptyStringIfNull implements TypeHandler<String> {

    @Override
    public String getResult(ResultSet rs, String columnName) throws SQLException {
     return (rs.getString(columnName) == null) ? "" : rs.getString(columnName); 
    }

    @Override
    public String getResult(ResultSet rs, int columnIndex) throws SQLException {
     return (rs.getString(columnIndex) == null) ? "" : rs.getString(columnIndex);
    }
    <span></span>@Override
    public String getResult(CallableStatement cs, int columnIndex)   throws SQLException {
     return (cs.getString(columnIndex) == null) ? "" : cs.getString(columnIndex);
    }
    @Override
    public void setParameter(PreparedStatement ps, int arg1, String str, JdbcType jdbcType) <span></span><span style="font-size:9pt;line-height:1.5;">throws SQLException {</span><span style="font-size:9pt;line-height:1.5;"> }</span><span style="font-size:9pt;line-height:1.5;">}</span>

继续在resultMap中使用,即可配置age的默认值(上述代码中age的默认值为”“)

<resultMap id="list" type="java.util.LinkedHashMap">
    <result property="name" column="name" />
    <result property="sex" column="sex" />
    <result property="age" column="age" typeHandler="com.demo.EmptyStringIfNull"/>
</resultMap>
<think>好的,我需要解决用户提到的MyBatis中resultType字段映射为null的问题。首先,根据用户提供的引用内容,问题可能出在字段名映射上。比如引用[1]提到MyBatis默认会自动将下划线转换为驼峰,导致字段无法映射,结果返回null。这可能是一个常见的原因,用户需要开启驼峰命名转换。 然后,用户提供的引用[2]和[3]也提到了类似的问题,使用resultType=map时,如果数据库字段为null,可能导致key存在。解决方法是用resultMap显式映射字段,或者使用类型处理器处理null值。这里可能需要指导用户如何配置resultMap,确保每个字段都有对应的映射。 另外,引用[4]指出当实体类使用了有参构造函数时,MyBatis可能会按构造参数顺序赋值,导致字段错乱。这时候需要检查实体类的构造函数,避免使用@AllArgsConstructor注解,或者确保字段顺序一致。 还有引用[5]提到参数类型的问题,使用基本类型可能导致判断空值问题,应使用包装类。这可能与映射无关,但需要提醒用户注意参数类型的正确使用。 综合以上信息,我需要分步骤给出解决方案,包括开启驼峰命名、使用resultMap、处理实体类构造函数、检查字段名一致性,以及处理null值的方法。同时,需要确保语言简洁,结构清晰,符合用户的要求。</think>### MyBatis中resultType字段映射为null的解决方案 #### 1. **开启驼峰命名自动转换(核心问题)** MyBatis默认启用数据库下划线字段到Java驼峰属性的自动映射。需在配置文件中开启: ```xml <settings> <setting name="mapUnderscoreToCamelCase" value="true"/> <!-- 关键配置 --> </settings> ``` 若使用Spring Boot,可在`application.yml`中添加: ```yaml mybatis: configuration: map-underscore-to-camel-case: true ``` *适用场景*:数据库字段为`user_name`,Java属性为`userName`[^1][^3]。 --- #### 2. **使用resultMap替代resultType** 当字段存在特殊映射关系或需处理null值时,推荐显式定义映射规则: ```xml <resultMap id="UserMap" type="User"> <result property="userName" column="user_name"/> <result property="age" column="age" typeHandler="org.apache.ibatis.type.IntegerTypeHandler"/> </resultMap> ``` *优势*: - 可自定义字段对应关系 - 支持空值类型处理器(如将null转为空字符串)[^2][^5] --- #### 3. **检查实体类构造函数(易错点)** 若实体类使用**全参构造器**(如Lombok的`@AllArgsConstructor`),需确保: 1. SQL查询字段顺序与构造器参数顺序一致 2. 或移除全参构造器,使用默认无参构造器+setter方法 *错误示例*: ```java @AllArgsConstructor // 可能导致字段值错乱 public class User { private String userName; private Integer age; } ``` *解决方案*:改用`@NoArgsConstructor`和`@Setter`[^4]。 --- #### 4. **字段名严格匹配** 验证以下对应关系: | 数据库字段 | Java属性 | 是否匹配 | |-----------|----------|---------| | `create_time` | `createTime` | ✅(需开启驼峰) | | `address` | `address` | ✅(直接匹配) | | `user_name` | `username` | ❌(缺少驼峰转换) | --- #### 5. **处理NULL值的特殊方法** 针对查询结果中的null字段: - **SQL层处理**:使用`COALESCE(column, defaultValue)` - **MyBatis类型处理器**: ```xml <resultMap ...> <result column="description" property="description" typeHandler="com.example.EmptyStringIfNull"/> </resultMap> ``` 实现`TypeHandler`接口处理null值转换[^2]。 --- #### 验证步骤 1. 打印执行的SQL语句,确认实际查询字段名 2. 检查返回的ResultSet字段与映射配置是否一致 3. 使用调试工具查看MyBatis生成的映射关系
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值