如何将枚举与 JPA 一起使用
我有一个现有的电影租赁系统数据库。每部电影都有一个评级属性。在SQL中,他们使用约束来限制此属性的允许值。
CONSTRAINT film_rating_check CHECK
((((((((rating)::text = ''::text) OR
((rating)::text = 'G'::text)) OR
((rating)::text = 'PG'::text)) OR
((rating)::text = 'PG-13'::text)) OR
((rating)::text = 'R'::text)) OR
((rating)::text = 'NC-17'::text)))
我认为使用Java枚举将约束映射到对象世界中会很好。但是,由于“PG-13”和“NC-17”中的特殊字符,因此不可能简单地获取允许的值。所以我实现了以下枚举:
public enum Rating {
UNRATED ( "" ),
G ( "G" ),
PG ( "PG" ),
PG13 ( "PG-13" ),
R ( "R" ),
NC17 ( "NC-17" );
private String rating;
private Rating(String rating) {
this.rating = rating;
}
@Override
public String toString() {
return rating;
}
}
@Entity
public class Film {
..
@Enumerated(EnumType.STRING)
private Rating rating;
..
使用 toString() 方法,方向枚举 -> 字符串工作正常,但字符串 ->枚举不起作用。我得到以下异常:
[TopLink Warning]: 2008.12.09 01:30:57.434--ServerSession(4729123)--Exception [TOPLINK-116] (Oracle TopLink Essentials - 2.0.1 (Build b09d-fcs (12/06/2007)):oracle.toplink.essentials.exceptions.exceptions.DescriptorException Exception Description: 未为字段 [FILM.评级]。Mapping: oracle.toplink.essentials.mappings.DirectToFieldMapping[rating-->FILM.RATING] Descriptor: RelationalDescriptor(de.fhw.nsdb.entities.Film --> [DatabaseTable(FILM)])
干杯
蒂莫