自动映射枚举
我们在 mybatis 的 EnumOrdinalTypeHandler(基于枚举常量序号) 和 EnumTypeHandler(基于枚举常量名) 之外
提供了更加灵活的枚举处理器 MybatisEnumTypeHandler(基于枚举常量属性)
只需要对枚举进行声明,即可实现枚举的自动映射
未进行声明的枚举则根据 mybatis的defaultEnumTypeHandler 的默认值EnumTypeHandler 来进行映射
public class User { private String name; // 名字 private AgeEnum age; // 年龄 private GradeEnum grade; // 年级}枚举声明
声明该枚举使用 MybatisEnumTypeHandler(基于枚举常量属性) 进行映射
方式一:注解标记
枚举属性使用 @EnumValue 注解,指定枚举值在数据库中存储的实际值。支持枚举类中的任意字段,如序号或编码。
@Getter@AllArgsConstructorpublic enum GradeEnum { PRIMARY(1, "小学"), SECONDARY(2, "中学"), HIGH(3, "高中");
@EnumValue // 标记数据库存的值是code private final int code; // 其他属性...}方式二:实现接口
实现 IEnum 接口,实现 getValue 方法,指定枚举值在数据库中存储的实际值。支持枚举类中的任意字段,如序号或编码。
@Getter@AllArgsConstructorpublic enum AgeEnum implements IEnum<Integer> { ONE(1, "一岁"), TWO(2, "二岁"), THREE(3, "三岁");
private final int value; private final String desc;
@Override public Integer getValue() { return this.value; }}未声明枚举
未声明的枚举将使用 mybatis 的 defaultEnumTypeHandler 的默认值 EnumTypeHandler 进行映射
可以通过修改全局配置来变更,不过这对上面步骤声明的枚举无效
修改全局 defaultEnumTypeHandler
yml 配置文件中配置:
mybatis-plus: configuration: default-enum-type-handler: xx.xx.xx.MyEnumTypeHandler或者通过自定义配置类:
@Configurationpublic class MybatisPlusAutoConfiguration {
@Bean public MybatisPlusPropertiesCustomizer mybatisPlusPropertiesCustomizer() { return properties -> { GlobalConfig globalConfig = properties.getGlobalConfig(); globalConfig.setBanner(false); MybatisPlusProperties.CoreConfiguration configuration = new MybatisPlusProperties.CoreConfiguration(); configuration.setDefaultEnumTypeHandler(MyEnumTypeHandler.class); properties.setConfiguration(configuration); }; }}或者其他
号外参考: 如何序列化枚举值为前端返回值
Jackson
一、重写 toString 方法
Spring Boot
@Beanpublic Jackson2ObjectMapperBuilderCustomizer customizer() { return builder -> builder.featuresToEnable(SerializationFeature.WRITE_ENUMS_USING_TO_STRING);}Jackson 独立使用
ObjectMapper objectMapper = new ObjectMapper();objectMapper.configure(SerializationFeature.WRITE_ENUMS_USING_TO_STRING, true);在枚举中重写 toString 方法,以上两种方式任选其一。
二、注解处理
public enum GradeEnum { PRIMARY(1, "小学"), SECONDORY(2, "中学"), HIGH(3, "高中");
GradeEnum(int code, String descp) { this.code = code; this.descp = descp; }
@EnumValue @JsonValue // 标记响应json值 private final int code;}Fastjson
一、重写 toString 方法
全局处理方式
FastJsonConfig config = new FastJsonConfig();config.setSerializerFeatures(SerializerFeature.WriteEnumUsingToString);局部处理方式
@JSONField(serialzeFeatures = SerializerFeature.WriteEnumUsingToString)private UserStatus status;在枚举中重写 toString 方法,以上两种方式任选其一。
通过以上步骤,你可以优雅地在 MyBatis-Plus 中使用枚举属性,并且能够方便地将枚举值序列化为前端所需的格式。