Mybatis使用TypeHandler实现Java类型与数据库类型的自定义转换

TypeHandler

当 SpringBoot 项目中使用到Mybatis时,通常情况下程序中使用的各种基本数据类型在数据库中都有定义,如 String - VARCHAR;
但当使用一些数据库中没有定义的数据类型时,如 Serializable ,此时 Mybatis 无法在数据库的数据类型和程序中的数据类型之间进行转换,就需要使用到自定义 TypeHandler;

通过实现 BaseTypeHandler<需要转换的Java类型> 来自定义类型的转换

举例将 Java 中的 Serializable 转换为 数据库中的 BIGINT

@MappedTypes(Serializable.class)
@MappedJdbcTypes(JdbcType.BIGINT)
public class SerializableTypeHandler extends BaseTypeHandler<Serializable> {

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, Serializable parameter, JdbcType jdbcType) throws SQLException {
        ps.setObject(i, parameter, JdbcType.BIGINT.TYPE_CODE);
    }

    @Override
    public Serializable getNullableResult(ResultSet rs, String columnName) throws SQLException {
        long result = rs.getLong(columnName);
        return result == 0 && rs.wasNull() ? null : result;
    }

    @Override
    public Serializable getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        long result = rs.getLong(columnIndex);
        return result == 0 && rs.wasNull() ? null : result;
    }

    @Override
    public Serializable getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        long result = cs.getLong(columnIndex);
        return result == 0 && cs.wasNull() ? null : result;
    }
}

在程序启动时需要向Mybatis的TypeHandlerRegistry中注册自定义的TypeHandler

SpringBoot注册示例:

public class Test implements ApplicationContextAware {
    public static void main(String[] args) {
        ApplicationContext applicationContext = SpringApplication.run(Test.class, args);
        SpringBeanLoader.setApplicationContext(applicationContext);
    }

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        SqlSessionTemplate bean = applicationContext.getBean(SqlSessionTemplate.class);
        Configuration configuration = bean.getConfiguration();
        TypeHandlerRegistry typeHandlerRegistry = configuration.getTypeHandlerRegistry();
        typeHandlerRegistry.register(SerializableTypeHandler.class);
    }
}

同时,需要定义数据库类型转回Java数据类型

此时需要在使用到该属性的mapper文件中通过resultMap定义:

	    <resultMap id="BASE_RESULTMAP" type="***.entity.Test">
        	<id column="test_id" property="id" typeHandler="***.handler.SerializableTypeHandler"/>
    	    <result column="test_name" jdbcType="VARCHAR" property="name"/>
        </resultMap>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要将自定义类型转换为JSON集合,可以按照以下步骤操作: 1. 创建一个MyBatis TypeHandler实现类,实现TypeHandler接口,或者继承BaseTypeHandler类。例如,可以创建一个名为JsonListTypeHandler的类。 2. 在TypeHandler实现类中重写setNonNullParameter方法和getNullableResult方法。setNonNullParameter方法用于将Java对象转换数据库字段值,getNullableResult方法用于将数据库字段值转换Java对象。 3. 在setNonNullParameter方法中,可以使用JSON库(如Jackson或GSON)将Java对象转换为JSON字符串,然后将JSON字符串设置到PreparedStatement对象中。 4. 在getNullableResult方法中,可以从ResultSet对象中获取数据库字段值,并使用JSON库将JSON字符串转换Java对象。 5. 在MyBatis配置文件(如mybatis-config.xml)中注册这个TypeHandler。可以通过typeHandlers标签将TypeHandler实现类与自定义Java类型关联起来。例如,可以添加以下配置: ```xml <typeHandlers> <typeHandler handler="com.example.JsonListTypeHandler" javaType="com.example.CustomTypeList"/> </typeHandlers> ``` 这里的"com.example.JsonListTypeHandler"是TypeHandler实现类的完整类名,"com.example.CustomTypeList"是自定义Java类型的完整类名。 6. 在映射文件中,使用自定义Java类型和对应的数据库字段。例如: ```xml <resultMap id="customTypeListMap" type="com.example.CustomTypeList"> <id property="id" column="id" /> <result property="name" column="name" /> </resultMap> ``` 通过以上步骤,就可以将自定义类型转换为JSON集合了。在查询时,MyBatis将自动应用TypeHandler,将数据库字段值转换Java对象;在插入或更新时,MyBatis将自动应用TypeHandler,将Java对象转换数据库字段值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值