java - JPA eclipselink 实体之间的继承 : oracle database

标签 java oracle jpa eclipselink jpa-2.0

我在 vaadin 中的 Web 应用程序遇到了一个小问题,我正在使用 jpa 和 eclipselink 进行映射。我有三个实体:

                    encaiss (@MappedSuperclass contains just Id)
                       |
                       |
                  Encaissement (it contains the main and common properties)
                     /              \
                    /                \
   Encaissement_Technique          Encaissement_espece

当我创建一个类型为“Espece”的实体“Encaissement”时,它在表 Encaissement 中创建良好,但它不存在于表 Encaissement_espece 中。

我想我应该根据 @MappedSuperclass 类中的标识符 (ID) 连接两个表。我将不胜感激管理我的下属类(即 Encaissement_Technique 和 Encaissement_espece)的任何帮助,因为我的下一步是将记录从简单的表单添加到这两个表中(因此,如果我有一个存在于 Encaissement 中的字段“libelle”,但不在 Encaissement_Espece 中怎么能做出这样的指令:

Encaissement_Espece  espece= new Encaissement_Espece();
espece.setLibelle(field.getValue().toString()); 

这些是我的实体:

encaiss,此类仅包含所有类的 Id

@MappedSuperclass
public abstract class encaiss {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO, generator="encaiss_seq_gen")
    @SequenceGenerator(name="encaiss_seq_gen", sequenceName="ENCAISSEMENT_SEQ", allocationSize = 1, initialValue = 1)
    protected Integer id_encaissement;

    public Integer getId_encaissement() {
        return id_encaissement;
    }

    public void setId_encaissement(Integer id_encaissement) {
        this.id_encaissement = id_encaissement;
    }
}

Encaissement(扩展 encaiss 只是为了拥有一个 Id)

@Entity
@Inheritance(strategy=InheritanceType.JOINED)
@DiscriminatorColumn(name="ENCAISS_TYPE")
@Table(name="ENCAISSEMENT")
public class Encaissement extends encaiss implements Serializable{

    @ManyToOne(cascade = CascadeType.PERSIST, fetch = FetchType.LAZY)
    @JoinColumn(name = "ID_CLIENT")
    private Client Client;
@Column(name="ENCAISS_TYPE")
    protected String encaiss_type;
    @Column(name="LIBELLE")
    protected String libelle;
    @Column(name="PIECE_JOINTE")
    protected String piece_jointe;
    @Embedded
    protected Avis_Recette avis_recette;

    public Encaissement(String encaiss_type, String libelle, String piece_jointe){
        this.encaiss_type=encaiss_type;
        this.libelle=libelle;
        this.piece_jointe=piece_jointe;
    }

    public Encaissement(){

    }

}

Encaissement_Espece,继承自Encaissement

@Entity
@DiscriminatorValue("Espece")
@Table(name="ENCAISSEMENT_ESPECE")
public class Encaissement_Espece extends Encaissement{

    public Caisse getCaisse() {
        return caisse;
    }

    public void setCaisse(Caisse caisse) {
        this.caisse = caisse;
    }

    public float getMontant() {
        return montant;
    }

    public void setMontant(float montant) {
        this.montant = montant;
    }

    @ManyToOne(cascade = CascadeType.PERSIST, fetch = FetchType.LAZY)
    @JoinColumn(name = "ID_CAISSE")
    private Caisse caisse;

    @Column(name = "MONTANT")
    private float montant;

    public Encaissement_Espece(float montant){
        this.montant=montant;
    }

    public Encaissement_Espece(){

    }

}

Encaissement_Technique,继承自Encaissement

@Entity
@DiscriminatorValue("Technique")
@Inheritance(strategy=InheritanceType.JOINED)
@DiscriminatorColumn(name="ENCAISS_TECHNIQUE_TYPE")
@Table(name="ENCAISSEMENT_TECHNIQUE")
public class Encaissement_Technique extends Encaissement implements Serializable{

    public Banque getBanque() {
        return banque;
    }

    public void setBanque(Banque banque) {
        this.banque = banque;
    }

    public float getPrimeCoass() {
        return primeCoass;
    }

    public void setPrimeCoass(float primeCoass) {
        this.primeCoass = primeCoass;
    }
    public Set<Periode> getPeriode() {
        return periode;
    }

    public void setPeriode(Set<Periode> periode) {
        this.periode = periode;
    }

    public String getEncaiss_technique_type() {
        return encaiss_technique_type;
    }

    public void setEncaiss_technique_type(String encaiss_technique_type) {
        this.encaiss_technique_type = encaiss_technique_type;
    }
@Column(name="PRIMECOASS")
    protected float primeCoass;
    @Column(name="ENCAISS_TECHNIQUE_TYPE")
    protected String encaiss_technique_type;

    public Encaissement_Technique(float primeCoass, String encaiss_technique_type){
        this.primeCoass=primeCoass;
        this.encaiss_technique_type=encaiss_technique_type;
    }

    public Encaissement_Technique(){

    }

}

This is a screen shot of the tables' description

我希望我能找到相关的答案,因为我徒劳地搜索了这个。这会对我有很大帮助。

谢谢。

最佳答案

“当我创建一个类型为“Espece”的实体“Encaissement”时,它在表 Encaissement 中创建得很好,但它不存在于表 Encaissement_espece 中。”此语句表明您有一个 Encaissement 实例,并期望 JPA 只需更改 encaiss_type 值即可将其转换为 Encaissement_Espece 实例。 Java 对象继承不是这样工作的,这正是 JPA 继承试图映射到关系数据库的方式。 java 中的对象不能简单地通过设置标志来更改它的内容 - 如果您希望以不同的方式表示数据,则需要创建一个新实例。

在这种情况下,您需要创建 Encaissement_Espece 类的实例。由于此类映射到 Encaissement 和 Encaissement_espece 表,JPA 将自动在这两个表中插入一行来表示该对象。当您创建 Encaissement 实例时,一行将进入 Encaissement 表,而当您创建 Encaissement_Technique 实例时,一行将进入 Encaissement_Technique 和 Encaissement 表。如果您希望在持久化对象后更改其类型,则需要删除旧实例,刷新,然后持久化新实例。

正如另一个答案中提到的, encaiss_type 是通过类类型本身控制的,因此不需要映射。拥有一个可能会方便查询或访问(尽管您可以只使用等的实例);应将其标记为 insertable=false、updatable=false,这样您就不会尝试直接修改该值。

关于java - JPA eclipselink 实体之间的继承 : oracle database,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29267409/

相关文章:

spring - 在 Spring JPA Hibernate 中使用蛇形案例

java - 如何获取联系人号码的组ID(Android)

java - RichFaces 丰富 :tree nodeSelectListener not being listened to

mysql - 为什么删除重复记录时出现 max(rowid) 或 min(rowid) ?

java - JPA/Hibernate 选择查询返回重复记录

java - 在什么类型的应用程序或场景中 PL/SQL 作为后端更好?

hibernate - 非主键列的自动递增数字生成

java - 被测单元 : Impl or Interface?

java - 如何使用更改监听器 JavaFX 在两个 ListView 之间移动项目

甲骨文分析问题