mybatis返回map类型数据空值字段不显示(三种解决方法)

一、查询sql添加每个字段的判断空

  1. IFNULL(rate,'') as rate

二、ResultType利用实体返回,不用map

三、springMVC+mybatis查询数据,返回resultType=”map”时,如果数据为空的字段,则该字段省略不显示,可以通过添加配置文件,规定查询数据为空是则返回null。

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


spring-mybatis.xml

  1. <!-- spring和MyBatis完美整合,添加mybatis的配置映射文件 -->
  2.   <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  3.     <property name="dataSource" ref="dataSource"/>
  4.     <property name="configLocation" value="classpath:mybatis-configuration.xml"/>
  5.     <!-- 自动扫描mapping.xml文件 -->
  6.     <property name="mapperLocations" value="classpath:mapping/*.xml"></property>
  7.   </bean>


如果想要配置rate的默认值,例如“”字符串,则可以建立一个类,实现Mybatis的TypeHandler接口

  1. public class EmptyStringIfNull implements TypeHandler<String> {
  2.     @Override
  3.     public String getResult(ResultSet rs, String columnName) throws SQLException {
  4.      return (rs.getString(columnName) == null) ? "" : rs.getString(columnName); 
  5.     }
  6.     @Override
  7.     public String getResult(ResultSet rs, int columnIndex) throws SQLException {
  8.      return (rs.getString(columnIndex) == null) ? "" : rs.getString(columnIndex);
  9.     }
  10.     @Override
  11.     public String getResult(CallableStatement cs, int columnIndex)   throws SQLException {
  12.      return (cs.getString(columnIndex) == null) ? "" : cs.getString(columnIndex);
  13.     }
  14.     @Override
  15.     public void setParameter(PreparedStatement ps, int arg1, String str, JdbcType jdbcType) throws SQLException { }}


在sql.xml文件定义与使用如下如下

  1. <resultMap id="find" type="java.util.LinkedHashMap">
  2.     <result property="name" column="name" />
  3.     <result property="phone" column="phone" />
  4.     <result property="rate" column="rate" typeHandler="com.mybatis.EmptyStringIfNull"/>
  5. </resultMap>

--------------------- 
作者:生命不息_战斗不止 
来源:CSDN 
原文:https://blog.csdn.net/lulidaitian/article/details/70941769?utm_source=copy 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值