Mybatis针对枚举值的处理
介绍
1. 用户管理中存储男女对应的key值100、101
2. 定义枚举类GenderEnum 继承 DbEnum接口
@JsonFormat(shape = JsonFormat.Shape.OBJECT)
public interface DbEnum extends Serializable {
public Integer getKey();
}
@AllArgsConstructor
public enum GenderEnum implements DbEnum{
MAIL(100, "男"),
FEMAIL(101, "女"),
UNKNOWN(102, "未知");
;
private Integer key;
@JsonValue
private String value;
public String getValue() {
return value;
}
@Override
public Integer getKey() {
return key;
}
}
3.定义枚举类的处理器
public class EnumTypeHandler extends BaseTypeHandler<DbEnum> {
private Class<DbEnum> enumClass;
public EnumTypeHandler(Class<DbEnum> enumClass) {
this.enumClass = enumClass;
}
@Override
public void setNonNullParameter(PreparedStatement preparedStatement, int i, DbEnum dbEnum, JdbcType jdbcType) throws SQLException {
preparedStatement.setInt(i, dbEnum.getKey());
}
@Override
public DbEnum getNullableResult(ResultSet resultSet, String s) throws SQLException {
int anInt = resultSet.getInt(s);
return getEnum(anInt);
}
@Override
public DbEnum getNullableResult(ResultSet resultSet, int i) throws SQLException {
return getEnum(resultSet.getInt(i));
}
@Override
public DbEnum getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
return getEnum(callableStatement.getInt(i));
}
private DbEnum getEnum(Integer key) {
DbEnum[] enumConstants = enumClass.getEnumConstants();
if (Objects.nonNull(enumConstants)) {
for (DbEnum enumConstant : enumConstants) {
if (Objects.equals(enumConstant.getKey(), key)) {
return enumConstant;
}
}
}
return null;
}
}
4.在xml文件中枚举字段定义枚举处理器
1)查询
2)插入
5.结果
1)插入
2) 查询