我想在JPA中映射一个地图,但我得到了一个例外:我的java代码如下所示:
Issue.java:
@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>();EmployeePosition是Enum,Employee是Entity。
我明白这一例外:
内部异常: java.sql.SQLException: ORA-00904:"EMPLOYEES":无效标识符 错误代码: 904调用:插入到ISSUE_EMPLOYEE (ISSUE_ID,EMPLOYEES,EMPLOYEEPOSITION_ID)值(?,?,?)bind => [27,B@18b85d,SERVICE
它似乎忽略了@JoinColumn注释,并试图在DB中插入对象。我的映射有什么问题/是否有可能匹配这样的实体?
发布于 2011-02-10 10:05:38
据我所知,当一个@OneToMany的值是一个实体时,您需要Map而不是@ElementCollection。就像这样:
@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中找不到,所以最好报告一下。
https://stackoverflow.com/questions/4955545
复制相似问题