首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JPA: Map a Map<Enum,Entity>

JPA: Map a Map<Enum,Entity>
EN

Stack Overflow用户
提问于 2011-02-10 09:54:22
回答 1查看 2.9K关注 0票数 2

我想在JPA中映射一个地图,但我得到了一个例外:我的java代码如下所示:

Issue.java:

代码语言:javascript
复制
@ElementCollection
@CollectionTable(
    name="ISSUE_EMPLOYEE",
    joinColumns=@JoinColumn(name="ISSUE_ID", referencedColumnName="ID")
)
@MapKeyColumn(name="EMPLOYEEPOSITION_ID")
@MapKeyConvert("myEnumConverter")
@JoinColumn(name="EMPLOYEE_ID")
private Map<EmployeePosition, Employee> namedEmployees = new Hashtable<EmployeePosition, Employee>();

EmployeePositionEnumEmployeeEntity

我明白这一例外:

内部异常: java.sql.SQLException: ORA-00904:"EMPLOYEES":无效标识符 错误代码: 904调用:插入到ISSUE_EMPLOYEE (ISSUE_ID,EMPLOYEES,EMPLOYEEPOSITION_ID)值(?,?,?)bind => [27,B@18b85d,SERVICE

它似乎忽略了@JoinColumn注释,并试图在DB中插入对象。我的映射有什么问题/是否有可能匹配这样的实体?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-02-10 10:05:38

据我所知,当一个@OneToMany的值是一个实体时,您需要Map而不是@ElementCollection。就像这样:

代码语言:javascript
复制
@OneToMany
@JoinTable(name = "ISSUE_EMPLOYEE",
    joinColumn = @JoinColumn(name = "ISSUE_ID"),
    inverseJoinColumn = @JoinColumn("EMPLOYEE_ID"))
@MapKeyColumn(name="EMPLOYEEPOSITION_ID") 
private Map<EmployeePosition, Employee> namedEmployees = new Hashtable<EmployeePosition, Employee>(); 

编辑:上面的映射在Hibernate中工作得很好,但是在EclipseLink中不工作。EMPLOYEEPOSITION_ID列是在ISSUE_EMPLOYEE中创建的,但不用于查询。这种情况不仅发生在枚举键上,而且也发生在其他原语类型上。

它看起来像EclipseLink中的一个bug。我在他们的Bugzilla中找不到,所以最好报告一下。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4955545

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档