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

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文件定义与使用如下如下

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值