Eclipselink继承实现



我正在尝试在我的项目中实现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

相关内容

  • 没有找到相关文章

最新更新