mybatis自定义类型转换器实现实体类属性和数据列之间的复杂映射关系

mybatis实现数据类和实体类属性之间的映射的关系方法

1.最简单的是可以通过查询的时候另取别名跟java实体类的字段一样,这样就可以实现数据映射,

2.通过resultmap设定数据库和实体类之间的映射关系

3.如果属性的命名是遵从驼峰命名法的,数据列名遵从下划线命名,则可以通过mybatis内置的映射方式实现,配置如下:

  
       
            
       

以上映射的规则都是基于基本的数据类型之间的转换,但是,假如业务需求,导致实体类有一个jsonObject的数据类型需要存到数据库的库表当中,这时候就没法实现映射了,因为mybatis内置的数据映射类型不支持jsonObject这种复杂的非常规的数据类型,怎么办呢?

这是就需要自定义实体类属性和数据列之间的数据类型转换器了;

mybatis提供了自定义类型转换器的支持,因此我们可以自定义自己的类型转化器,继承baseTypeHandler,其中泛型对象为要转换的数据类型对象,如下:

public class JsonObjectTypeHandler extends BaseTypeHandler {
    @Override  public void setNonNullParameter(PreparedStatement ps, int i, JSONObject parameter, JdbcType jdbcType) throws SQLException {
        ps.setString(i,JSONObject.toJSONString(parameter));  }

    @Override  public JSONObject getNullableResult(ResultSet rs, String columnName) throws SQLException {
        String str = rs.getString(columnName);  if (StringUtils.isBlank(str)) return null;  return JSONObject.parseObject(str);  }

    @Override  public JSONObject getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        String str = rs.getString(columnIndex);  if (StringUtils.isBlank(str)) return null;  return JSONObject.parseObject(str);  }

    @Override  public JSONObject getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        String str = cs.getString(columnIndex);  if (StringUtils.isBlank(str)) return null;  return JSONObject.parseObject(str);  }
}

实现4个抽象方法,四个方法的作用就是数据库和实体类属性之间的转换格式;get的方法是将数据库的值转换成java的jsonObject格式,set的方法作用相反;

然后还要在mybatis的配置文件mybatis-config增加该转换器的定义,如下:

  handler="priv.llf.mybatis.typeHandler.JsonObjectTypeHandler" javaType="com.alibaba.fastjson.JSONObject"/> 

然后就可以启动项目进行测试验证了;

你可能感兴趣的:(mybatis,spring)