解决mybatis空字段null字段不返回

Mybatis在使用resultMap来映射查询结果中的列,如果查询结果中包含空值的列(不是null),则Mybatis在映射的时候,不会映射这个字段,例如 查询 name,sex,age,数据库中的age字段没有值,Mybatis返回的map中只映射了 name和sex字段,而age字段则没有包含。
那么如何将age字段映射到map中呢。提供四种解决方法:

方法一:
MyBatis 不知道你传入的 null 参数对应的 jdbc 类型是什么,因为在 MyBatis 看来,null 在数据库中可以为多种类型(例如,可以为 CHAR、VARCHAR、DATE 等),于是 MyBatis 就傻眼了,解决办法自然是你要告诉 MyBatis 这个 null 对应的 jdbc 类型是什么。于是得出的答案如下:

  在你相应的 Mapper 中,传入该参数的地方写明 jdbc 类型即可,比如原来传参数是这样写的:#{myNullParameter},把它改成这样写即可:#{myNullParameter, jdbcType=VARCHAR}

方法二:
使用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 {
@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);
}
@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) throws SQLException { }}
继续在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>

网上有些资料中提到可以使用 defaultValue 和 nullValue的配置,但是这中配置是ibatis的用法,在Mybatis中已经移除。

方法四:


<!-- 表示在mybatis.mapping包或以下所有目录中,以 Mapper.xml结尾所有文件 -->  
<property name="mapperLocations">  
    <value>classpath:com/cncounter/dao/oracle/**/*Mapper.xml</value>  
    <!--   
    <list>  
        <value>classpath:com/cncounter/dao/oracle/res/*Mapper.xml</value>  
        <value>classpath:com/cncounter/dao/oracle/user/*Mapper.xml</value>  
    </list>  
     -->  
</property>  
<!--   
<property name="configLocation">  
    <value>classpath:mybatis/mybatis-env-setting.xml</value>  
</property>  
 -->  
<!--  切换一种方式,不配置configLocation  -->  
<property name="configurationProperties">  
    <props>  
        <prop key="cacheEnabled">true</prop>  
        <prop key="callSettersOnNulls">true</prop>  
    </props>  
</property>  

方法五:
对象属性自己初始化值

转载于:https://www.cnblogs.com/jpfss/p/7813534.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值