mybatis plus 集合枚举映射
时间: 2025-05-04 13:32:52 浏览: 27
### MyBatis Plus 中集合和枚举的映射实现
#### 枚举类型的映射
在MyBatis-Plus中,对枚举的支持较为简便。通过`@EnumValue`注解以及自定义处理器的方式能够更轻松地完成枚举类型与数据库字段之间的转换[^1]。
对于简单的枚举映射,可以直接利用内置的功能来处理基本的数据交换需求。例如性别枚举:
```java
public enum Sex {
MAN,
WOMAN;
}
```
当涉及到实体类时,则可以通过如下方式声明属性并关联上述枚举:
```java
@Data
@TableName("student")
public class Student {
private String stuId;
@TableField(typeHandler = EnumTypeHandler.class)
private Sex sex;
}
```
这里使用了`typeHandler`指定为`EnumTypeHandler`以便于自动处理枚举值与字符串间的相互转化[^2]。
#### 集合类型的映射
针对更为复杂的场景——即需要存储多个枚举实例组成的列表或数组形式的情况,在MyBatis-Plus里同样提供了灵活的方法来进行映射操作。一种常见的做法是采用JSON序列化/反序列化的手段保存这些数据结构至单一列内;另一种则是创建额外的关系表以支持一对多关系建模。
如果选择前者(推荐),则需引入Jackson库或其他类似的JSON解析器,并配置相应的TypeHandler:
```xml
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>${jackson.version}</version>
</dependency>
```
接着编写自定义的TypeHandler用于处理特定业务逻辑下的对象持久化过程:
```java
import com.baomidou.mybatisplus.extension.handlers.AbstractJsonTypeHandler;
import com.fasterxml.jackson.databind.ObjectMapper;
// 假设有一个名为Hobby的枚举...
public class HobbyListTypeHandler extends AbstractJsonTypeHandler<List<Hobby>> {
public HobbyListTypeHandler() {
super(new ObjectMapper());
}
@Override
protected List<Hobby> parse(String json) throws Exception {
return getObjectMapper().readValue(json, new TypeReference<List<Hobby>>() {});
}
// ...其他必要的方法重写
}
```
最后一步是在对应的Entity类上应用此TypeHandler:
```java
@TableField(typeHandler = HobbyListTypeHandler.class)
private List<Hobby> hobbies;
```
这样就完成了从Java端到数据库层面完整的双向映射机制构建工作[^3]。
阅读全文
相关推荐


















