mybatis的配置 mybatis-config.xml
2,springBoot配置 application.properties 添加
#mybatis resultType equal map void null value
mybatis.configuration.call-setters-on-nulls=true
3,转换成JSON时
//导包
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
//代码
JSON.toJSONString(new HashMap<>(),SerializerFeature.WriteMapNullValue);
一、查询sql添加每个字段的判断空
IFNULL(rate,'') as rate二、ResultType利用实体返回,不用map
三、springMVC+mybatis查询数据,返回resultType=”map”时,如果数据为空的字段,则该字段省略不显示,可以通过添加配置文件,规定查询数据为空是则返回null。<?xml version="1.0" encoding="UTF-8"?>
/p>
"http://mybatis.org/dtd/mybatis-3-config.dtd">
spring-mybatis.xml
如果想要配置rate的默认值,例如“”字符串,则可以建立一个类,实现Mybatis的TypeHandler接口public class EmptyStringIfNull implements TypeHandler{
@Overridepublic String getResult(ResultSet rs, String columnName) throwsSQLException {return (rs.getString(columnName) == null) ? "": rs.getString(columnName);
}
@Overridepublic String getResult(ResultSet rs, int columnIndex) throwsSQLException {return (rs.getString(columnIndex) == null) ? "": rs.getString(columnIndex);
}
@Overridepublic String getResult(CallableStatement cs, int columnIndex) throwsSQLException {return (cs.getString(columnIndex) == null) ? "": cs.getString(columnIndex);
}
@Overridepublic void setParameter(PreparedStatement ps, int arg1, String str, JdbcType jdbcType) throwsSQLException { }}在sql.xml文件定义与使用如下如下