首页 > 其他 > 详细

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

时间:2020-07-18 11:19:42      阅读:99      评论:0      收藏:0      [点我收藏+]

mybatis的配置 mybatis-config.xml

<settings>
<!-- mybatis resultType equal map void null value -->
<setting name="callSettersOnNulls" value="true"/>
</settings>
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"?> <!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> spring-mybatis.xml <!-- spring和MyBatis完美整合,添加mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="configLocation" value="classpath:mybatis-configuration.xml"/> <!-- 自动扫描mapping.xml文件 --> <property name="mapperLocations" value="classpath:mapping/*.xml"></property> </bean> 如果想要配置rate的默认值,例如“”字符串,则可以建立一个类,实现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); } @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 { }} 在sql.xml文件定义与使用如下如下 <resultMap id="find" type="java.util.LinkedHashMap"> <result property="name" column="name" /> <result property="phone" column="phone" /> <result property="rate" column="rate" typeHandler="com.mybatis.EmptyStringIfNull"/> </resultMap>

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

原文:https://www.cnblogs.com/xianz666/p/13334560.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!