3

我有以下映射:

public enum JobType {
    CLEANER,
    CRAWLER, ...
 }


public class JobId implements Serializable {
    private int accId;
    private String env;
    private JobType jobType;
 }

@SuppressWarnings("serial")
@Entity
@Table(name = "jobs")
public class JobExecution {

    @EmbeddedId
    @AttributeOverrides({
        @AttributeOverride(name = "accId", column = @Column(name = "acc_id")),
        @AttributeOverride(name = "env", column = @Column(name = "env")),
        @AttributeOverride(name = "jobType", column = @Column(name = "agg_type")) })
    private JobId jobId;

    @Enumerated(EnumType.STRING)
    @Column(name = "Job_STATUS")
    private JobStatus jobStatus;

    //...  other staff 
}

作业状态枚举列写入 OK,其中包含字符串值。

但是 jobType 写的是序数值 (0,1,...) 而不是名称 (CLEANER, CRAWLER ...)。

我想将 JobType 枚举名称写入数据库,而不是它的 ordinal() 值。

我可以将哪个映射添加到 @EmbeddedId 以提示 jobType 列的此属性?

4

1 回答 1

3

这样做的方法是直接在字段上使用@Enumerated 注释:

@Enumerated(EnumType.STRING)

如果需要,我想您可以使用注释您的JobId类,@Embeddable然后将@Enumerated注释放在您的JobType字段中:

@Embeddable
public class JobId implements Serializable {
    private int accId;
    private String env;

    @Enumerated(EnumType.STRING)
    private JobType jobType;
}
于 2013-03-28T14:06:09.600 回答