110

我有一个类别休眠模型:

@Entity
@Table(name = "category")
public class Category {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Column(name = "id")
    private long id;

    @Column(name = "type")
    private String type;

其中有一个类型字符串字段。我还有一个 Java 枚举,它代表一个类别的类型:

public enum CategoryType {
    INCOME, OUTCOME;
}

我想用它来代替字符串类型。SQL 在 varchar 参数中接受两个不同的值:要么CategoryIncome要么CategoryOutcome。我希望 Category 模型类接受一个枚举变量 - 并在 hibernate 请求时以某种方式将其映射到字符串。

可能吗?

4

2 回答 2

210

是的,是可能的。它应该是:

@Enumerated(EnumType.STRING)
@Column(name = "category_type")
private CategoryType categoryType;
于 2013-04-13T13:39:06.263 回答
4

接受的答案对于PostgreSQL来说是不够的。我附上了对我有用的实现:

https://stackoverflow.com/a/64021041/5279996

于 2020-09-25T04:47:09.650 回答