我正在尝试在我的项目中实现ElcipseLink JPA2.0的继承。不能使用注释。只有XML映射。
这是我的代码。公共类DefaultEntity {}
public class SpecialEntity extends DefaultEntity {
public String name;
public int age;
}
public class AnotherSplEntity extends DefaultEntity {
long ts;
String pkey;
}
public class MyPersistableEntity {
public DefaultEntity de;
public void setMyPersistableEntity(DefaultEntity de) {
// any subclass can be assigned here.
this.de = de
}
这是我的ORM.xml
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<entity-mappings xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm" version="2.3">
<persistence-unit-metadata>
<exclude-default-mappings />
</persistence-unit-metadata>
<entity class="MyPersistableEntity">
<attributes>
<one-to-one name="de">
<cascade>
<cascade-all />
</cascade>
</one-to-one>
</attributes>
</entity>
<mapped-superclass class="DefaultEntity">
<attributes>
<id name="id" attribute-type="long">
<generated-value strategy="SEQUENCE" />
</id>
</attributes>
</mapped-superclass>
<entity class="SpecialEntity" >
<attributes>
<id name="id" attribute-type="long">
<generated-value strategy="SEQUENCE" />
</id>
<basic name="name" attribute-type="String" />
<basic name="age" attribute-type="int" />
</attributes>
</entity>
</entity-mappings>
我一直在"在关系属性[field de]中使用非实体[class DefaultEntity]作为目标实体"
如何使EclipseLink识别实际类分配和使用映射?
任何想法?最重要的是,它可以用EcliseLink完成吗?
谢谢Gopi
如果您希望引用为SpecialEntity,则需要设置目标实体,
看,http://en.wikibooks.org/wiki/Java_Persistence/Relationships Target_Entity
或者更好的是,将字段的类型更改为SpecialEntity。
如果可以,则不能使用MappedSuperclass,您需要创建DefaultEntity和Entity并映射继承
终于找到办法了。所以我用抽象类代替并创建了一个抽象类。不确定这是否是EclipseLink的错误。另一个问题是使用生成值策略"SEQUENCE"(可能是其他)不能正确生成序列。
我的表单如下图
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<entity-mappings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm" version="2.3">
<persistence-unit-metadata>
<exclude-default-mappings />
</persistence-unit-metadata>
<entity class="ABC">
<table name="" />
<attributes>
<id .......>
</id>
<basic name="ts" attribute-type="long" />
<one-to-one name="field-referring-to-abstract-class" >
<join-column name="ABSTRACT_ID"/>
<cascade>
<cascade-all />
</cascade>
</one-to-one>
</attributes>
</entity>
<entity class="ABSTRACT-CLASS" >
<table name="ABSTRACT-TABLE"/>
<inheritance strategy="TABLE_PER_CLASS" />
<attributes>
<id name="ABSTRACT_ID" attribute-type="String" >
<column name="ABSTRACT_ID" />
</id>
</attributes>
</entity>
<entity class="SUB-CLASS1-TO-ABSTRACT" access="FIELD">
<table name="SUBCLASS1"/>
<attributes>
<basic name="name" attribute-type="String" />
<basic name="age" attribute-type="int" />
</attributes>
</entity>
<entity class="SUB-CLASS2-TO-ABSTRACT" access="FIELD">
<table name="SUBCLASS2"/>
<attributes>
<basic name="city" attribute-type="String" />
<basic name="zipcode" attribute-type="int" />
</attributes>
</entity>
</entity-mappings>
所以,这是存储到适当的表,因为我们在子类中读取提供的PK,我提供保持唯一性。
希望这对你有帮助谢谢Gopi