mybatis jdbcType与javaBean之间转换处理

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/yzy199391/article/details/88689605


完整的依赖关系如下图:
在这里插入图片描述

Mapper 文件配置

<resultMap id="BaseResultMap" type="com.ximalaya.business.group.checkin.infrastructure.model.CheckinConfig" >
    <id column="CHECKIN_ID" property="checkinId" jdbcType="BIGINT" />
    <result column="TYPE" property="type" jdbcType="SMALLINT" />
    <result column="START_DATE" property="startDate" jdbcType="DATE" />
    <result column="END_DATE" property="endDate" jdbcType="DATE" />
    <result column="PROPERTIES" property="properties" jdbcType="VARCHAR" typeHandler="com.ximalaya.business.group.checkin.infrastructure.handler.MybatisJsonTypeHandler"/>
  </resultMap>

注意上述PROPERTIES属性中的typeHandler是转换的关键

java pojo

@Data
public class CheckinConfig {
    private Long checkinId;

    private Short type;

    private Date startDate;

    private Date endDate;

    private Map<String, Object> properties;

    public static final String POSTER_QR_CODE = "posterQrCode";

}

转换处理类

import com.fasterxml.jackson.annotation.JsonInclude;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;

import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Map;

import com.fasterxml.jackson.databind.ObjectMapper;
import org.apache.ibatis.type.MappedTypes;


/**
 * @author : yanzy
 * @date : 2019-03-20
 */
@MappedTypes(Map.class)
@MappedJdbcTypes(JdbcType.VARCHAR)
public class MybatisJsonTypeHandler<T extends Object> extends BaseTypeHandler<T> {

    private static final ObjectMapper mapper = new ObjectMapper();
    private Class<T> clazz;

    public MybatisJsonTypeHandler(Class<T> clazz) {
        if (clazz == null) throw new IllegalArgumentException("Type argument cannot be null");
        this.clazz = clazz;
    }

    public MybatisJsonTypeHandler() {
    }

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {
        ps.setString(i, this.toJson(parameter));
    }

    @Override
    public T getNullableResult(ResultSet rs, String columnName) throws SQLException {
        return this.toObject(rs.getString(columnName), clazz);
    }

    @Override
    public T getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        return this.toObject(rs.getString(columnIndex), clazz);
    }

    @Override
    public T getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return this.toObject(cs.getString(columnIndex), clazz);
    }

    private String toJson(T object) {
        try {
            return mapper.writeValueAsString(object);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    private T toObject(String content, Class<?> clazz) {
        if (content != null && !content.isEmpty()) {
            try {
                return (T) mapper.readValue(content, clazz);
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        } else {
            return null;
        }
    }

    static {
        mapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
    }
}

此类扩展了mybatis提供的BaseTypeHandler类,我们只需要自定义一个转换方法,如上例中的toObject()方法,然后重写getNullableResult()方法的所有重载,在其中运用转换方法,并返回结果即可。

猜你喜欢

转载自blog.csdn.net/yzy199391/article/details/88689605