mybatis枚举类型自定义处理类

 类都在包 default下创建

1、先定义一个接口类

public interface BaseEnum {

    public String getValue();

    public String getName();
    
}

2、让一个枚举类型实现这个接口

public enum EnumTest implements BaseEnum {
    TEST_ONE("test1", "测试一"),
    TEST_TWO("test2", "测试二");

    private EnumTest(String value, String name) {
        this.name = name;
        this.value = value;
    }
    
    private String name;
    
    private String value;
    
    @Override
    public String getName() {
        return this.name;
    }

    @Override
    public String getValue() {
        return this.value;
    }

    public static EnumTest enumValueOf(String value) {
        EnumTest[] values = EnumTest .values();
        for (EnumTest test : values) {
            if (value.equalsIgnoreCase(test.getValue())) {
                return test;
            }
        }
        
        return null;
    }

}

3、创建mybatis枚举类型处理类

public class BaseEnumTypeHandler<E extends BaseEnum> extends BaseTypeHandler<E> {

    private final Class<E> type;

    public BaseEnumTypeHandler(Class<E> type) {
        if (type == null) {
            throw new IllegalArgumentException("Type argument cannot be null");
        }
        this.type = type;
    }

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

    
    @Override
    public E getNullableResult(ResultSet rs, String columnName) throws SQLException {
        String s = rs.getString(columnName);
        BaseEnum[] baseEnumArr = this.type.getEnumConstants();
        E baseEnum = valueOfString(baseEnumArr, s);
        return baseEnum;
    }

    @Override
    public E getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        String s = rs.getString(columnIndex);
        BaseEnum[] baseEnumArr = this.type.getEnumConstants();
        E baseEnum = valueOfString(baseEnumArr, s);
        return baseEnum;
    }
    
    @Override
    public E getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        String s = cs.getString(columnIndex);
        BaseEnum[] baseEnumArr = this.type.getEnumConstants();
        E baseEnum = valueOfString(baseEnumArr, s);
        return baseEnum;
    }
    
    @SuppressWarnings("unchecked")
    private E valueOfString(BaseEnum[] baseEnumArr, String value) {
        if (baseEnumArr == null || StringUtils.isBlank(value)) {
            return null;
        }
        
        for (BaseEnum baseEnum : baseEnumArr) {
            if (value.equalsIgnoreCase(baseEnum.getValue())) {
                return (E) baseEnum;
            }
        }
        
        return null;
    }

}

4、在mybatis配制文件mybatis.cfg.xml里添加一个配制

<typeHandlers>
        <typeHandler handler="BaseEnumTypeHandler" javaType="EnumTest"/>
    </typeHandlers>

 

转载于:https://www.cnblogs.com/xtly2012/p/9111197.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值