2

我正在使用 JPA 注释,当我有关系 OneToMany - ManyToOne 时,当我在 ManyToOne 中看到我的实体时,joinColumn 始终为空值。

接下来我将展示我的示例,我有Product

  @Entity
  @Table(name = "PC_PRODUCT")

  public class Product extends LaunchEntity {

  private static final long serialVersionUID = 1L;

  @XmlElement(name = "Product_Name", required = true)
  protected String productName;

  @XmlElement(name = "Product_Description")
  protected String productDescription;

  @XmlElement(name = "Product_To_Charge")
  @OneToMany(mappedBy = "product", cascade=CascadeType.MERGE)
  protected List<ChargeRelation> productToCharge;

而且,这是我的 ChargeRelation 课程:

@Entity
@Table(name="PC_CHARGE_RELATION")
public class ChargeRelation
    extends RelationEntity
{

    private static final long serialVersionUID = 1L;

    @XmlElement(name = "Charge", required = true)
    @OneToOne(cascade = CascadeType.MERGE)
    protected Charge charge;

    @XmlTransient
    @ManyToOne(cascade=CascadeType.MERGE)
    @JoinColumn(name="PRODUCT_ID")
    protected Product product;

我正在读取一个 xml 文件,将数据转换为字符串,为我的根对象解组并保留该对象。

问题是当我在我的字符串中找到一个收费关系时,这些值被插入到收费关系表中,但product_id 的列始终为 null

我已经定义了所有的 setter 和 getter。我怎样才能强制它进行手动插入?谢谢

4

2 回答 2

2

请注意,JPA 提供程序在将其保存到数据库时反映了多对一关系的状态。

但是,JAXB 仅在 XML 解组期间填充一对多端,因此您需要在解组后手动填充多对一端。

于 2012-04-10T08:25:02.240 回答
2

注意: 我是EclipseLink JAXB (MOXy)负责人,也是JAXB 2 (JSR-222)专家组的成员。

EclipseLink JAXB (MOXy) 有一个名为的扩展@XmlInverseReference,允许您映射反向指针。

产品

@Entity
@Table(name = "PC_PRODUCT")
public class Product extends LaunchEntity {

    @XmlElement(name = "Product_To_Charge")
    @OneToMany(mappedBy = "product", cascade=CascadeType.MERGE)
    protected List<ChargeRelation> productToCharge;

}

电荷关系

@XmlInverseReference注释在您以前使用的地方使用@XmlTransient@XmlInverseReference就像@XmlTransient在封送操作期间一样,并且将在取消封送操作期间填充反向指针。

@Entity
@Table(name="PC_CHARGE_RELATION")
public class ChargeRelation extends RelationEntity {

    @XmlInverseReference(mappedBy = "productToCharge")
    @ManyToOne(cascade=CascadeType.MERGE)
    @JoinColumn(name="PRODUCT_ID")
    protected Product product;
}

了解更多信息

于 2012-04-10T09:59:19.933 回答