Envers是一个用于实现Hibernate的版本控制的库。在Envers中,我们可以使用枚举类型来表示实体的状态。默认情况下,Envers会将枚举类型的值保存为序数(整数值)。但是,有时候我们可能希望将枚举字符串保存到数据库中,而不是序数。下面是一个解决方法的代码示例:
首先,我们需要定义一个枚举类型,并使用@Enumerated
注解将其标记为Envers实体的属性:
public enum Status {
OPEN("Open"),
IN_PROGRESS("In Progress"),
CLOSED("Closed");
private String value;
Status(String value) {
this.value = value;
}
public String getValue() {
return value;
}
}
然后,在实体类中,我们可以使用@ColumnTransformer
注解来指定将枚举字符串保存到数据库中的转换逻辑:
@Entity
@Audited
public class EntityClass {
@Id
private Long id;
@Column
@Enumerated(EnumType.STRING)
@ColumnTransformer(
read = "status",
write = "CASE WHEN LOWER(status) IN ('open', 'in progress', 'closed') THEN LOWER(status) ELSE NULL END"
)
private Status status;
// getters and setters
}
在上面的示例中,我们使用@ColumnTransformer
注解的read
属性指定了从数据库中读取枚举值时的转换逻辑,使用write
属性指定了将枚举值写入数据库时的转换逻辑。
通过这种方式,我们可以将枚举字符串保存到数据库中,而不是序数。
上一篇:保存枚举名称在本地查询中
下一篇:保存没有id的优雅模型实例。