JPA插入枚举类型字段
程序员文章站
2022-03-02 15:25:06
...
JPA插入枚举类型字段,有三种方式:(1)插入枚举字面值 (2)插入枚举序号 (3)插入枚举中自定义的值
例如,我们有个枚举类:
public enum Gender {
BOY("1" , "boy" , "Boy");
GIRL("2" , "girl" , "Girl");
private int value;
private String s1;
private String s2;
//....省略
}
1. 插入枚举名称的值,即字符串
将BOY或GIRL存入表中,实体类字段如下:
public class Staff {
@Enumerated(EnumType.STRING)
private Gender gender;
//...省略
}
2. 插入枚举的序号,即ordinal。
ordinal的意思就是你在类中定义枚举的顺序,从0开始。这种方式并不常用,不清楚同学修改了枚举类容易导致业务异常。
而且JPA默认的方式(不加@Enumerated注解)就是这种。
例如将BOY存入表中,这种方式将存入0。将GIRL存入表中,这种方式将存入1;
public class Staff {
@Enumerated(EnumType.ORDINAL)
private Gender gender;
//...省略
}
3.插入枚举中的自定义值
例如:
public enum Gender {
BOY("1" , "boy" , "Boy");
Girl("2" , "girl" , "Girl");
private int value;
private String s1;
private String s2;
//....省略
}
如果想将BOY的数字1或者 “boy” 或者“Boy”存入表中,JPA默认是不支持的,需要自定义一个类实现特定接口: implements AttributeConverter<X,Y>。
以代码为例,详看注释,假如我想将BOY的1存入表中:
public class GenderConverter implements AttributeConverter<Gender, Integer>{
/**
* convertToDatabaseColumn方法是转换数据到表中
* 这里是将Gender 枚举的value存入表中
*/
@Override
public Integer convertToDatabaseColumn(Gender attribute) {
if(attribute == null){
throw new RuntimeException("Unknown Gender text : " + attribute);
}
return attribute.getValue();
}
/**
* convertToEntityAttribute方法是转换表中的值转换回数据
* 这里是将表中的枚举的value值转换成gender枚举
*/
@Override
public Gender convertToEntityAttribute(Integer dbData) {
for(Gender s : Gender.values()){
if(s.getValue() == (dbData)){
return s;
}
}
throw new RuntimeException("Unknown Gender text : " + dbData);
}
}
实例类:
public class Staff {
/**
* 利用 @Convert 指向自定义转换类GenderConverter
* 此时JPA会根据自定义转换规则对Gender枚举类进行存取
*/
@Convert(converter = GenderConverter.class)
private Gender gender;
//...省略
}
推荐阅读
-
Springboot JPA 枚举Enum类型存入到数据库的操作
-
JDBC如何插入Blob类型字段
-
Oracle 大文本Clob类型字段插入失败ORA-22275: invalid LOB locator specified
-
用Hibernate映射INT字段到枚举类型
-
MyBatis自定义TypeHandler处理枚举类型的字段
-
jpa建一个枚举类型---Hibernate注解之@Enumerated
-
jpa @Enumerated(EnumType.ORDINAL)处理枚举类型
-
MySQL插入datetime类型字段
-
JPA关于枚举类型的处理
-
JPA 枚举形式做为字段存数据库varcher