我的数据库表中有一列要映射到Java对象。 我用注释标记了所选列:
@Enumerated(EnumType.STRING)
private RoleType code;
问题是在数据库方面,除了我感兴趣的值之外,还有无效(在我正在执行的任务的上下文中)值,所以我想将它们映射到"未知&#34 ;类型。
ADMIN ("ADMIN "),
CLIENT ("CLIENT"),
SOMEBODY ("SOMEBODY"),
UNKNOWN ("UNKNOWN");
尝试上面的操作我得到了Hibernate映射错误。 是否可以使用Hibernate将枚举(ADMIN,CLIENT,SOMEBODY)中提到的值不同于3的值映射到某个默认枚举值(即UNKNOWN)?
编辑:
让事情更清楚
如何在Java端映射数据库端的值:
TYPE_1 ---> UNKNOWN
ADMIN ---> ADMIN
CLIENT ---> CLIENT
SOMEBODY ---> SOMEBODY
TYPE_2 ---> UNKNOWN
SOMEBODY_2 ---> UNKNOWN
答案 0 :(得分:0)
好吧,您可以运行更新查询以使它们都未知,但如果您不想这样做,您可以创建自己的usertype: http://www.gabiaxel.com/2011/01/better-enum-mapping-with-hibernate.html