首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JPA实体间的eclipselink继承: oracle数据库

JPA实体间的eclipselink继承: oracle数据库
EN

Stack Overflow用户
提问于 2015-03-25 22:03:07
回答 2查看 95关注 0票数 2

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

代码语言:javascript
复制
                    encaiss (@MappedSuperclass contains just Id)
                       |
                       |
                  Encaissement (it contains the main and common properties)
                     /              \
                    /                \
   Encaissement_Technique          Encaissement_espece

当我创建一个以"Espece“为类型的实体" Encaissement”时,它在表封装中被很好地创建,但它不存在于表Encaissement_espece中。

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

代码语言:javascript
复制
Encaissement_Espece  espece= new Encaissement_Espece();
espece.setLibelle(field.getValue().toString()); 

这些是我的实体:

encaiss,这个类只包含所有类的Id

代码语言:javascript
复制
@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;
    }
}

封装(只为了有一个Id)

代码语言:javascript
复制
@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,继承自

代码语言:javascript
复制
@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,继承自

代码语言:javascript
复制
@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(){

    }

}

我希望我能找到一个中肯的答案,因为我找不到这一点。会对我有很大帮助的。

谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-26 01:25:44

当我创建一个以"Espece“为类型的实体" Encaissement”时,它在表封装中被很好地创建,但它在表Encaissement_espece中不存在。该语句建议您有一个Encaissement实例,并期望JPA通过更改Encaissement_Espece值将其转换为encaiss_type实例。Java对象继承不是这样工作的,这就是JPA继承试图映射到关系数据库的方式。java中的对象不能仅仅通过设置一个标志来改变它是什么--如果您想要以不同的方式表示数据,就需要创建一个新实例。

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

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

票数 2
EN

Stack Overflow用户

发布于 2015-03-25 23:37:36

移除

代码语言:javascript
复制
@Column(name="ENCAISS_TYPE")
protected String encaiss_type;

从Encaissment那里。

它将由JPA自动处理。它应该能解决这个问题。

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

https://stackoverflow.com/questions/29267409

复制
相关文章

相似问题

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