嗨,我有一个实体

OfferItem与这两个关系manyToOne

     @ManyToOne
@JoinColumn(name = "offer_id", nullable = false, insertable = false, updatable = false)
@XmlTransient
@Getter
@Setter
private Offer offer;

@ManyToOne
@JoinColumn(name = "item_id", nullable = false, insertable = false, updatable = false)
@XmlTransient
@Getter
@Setter
private Item item;


并在数据库上配置外键

             <addForeignKeyConstraint baseTableName="offer_item"
                             baseColumnNames="item_id"
                             constraintName="item_offer_item_fk"
                             referencedTableName="item"
                             onDelete="CASCADE" onUpdate="CASCADE"
                             referencedColumnNames="id"/>

    <addForeignKeyConstraint baseTableName="offer_item"
                             baseColumnNames="offer_id"
                             constraintName="offers_offer_item_fk"
                             onDelete="CASCADE" onUpdate="CASCADE"
                             referencedColumnNames="id"
                             referencedTableName="offer"/>


与要约的关系是双向的,所以在要约实体上,我与OfferItem有这种关系

          @OneToMany(orphanRemoval = true, cascade = {CascadeType.ALL})
@JoinColumn(name = "offer_id", nullable = false)
@XmlElementWrapper
@Getter
private List<OfferItem> offerItems = new ArrayList<>();


在项目上,我没有投标关系,因为没有必要。

现在的问题是,当我在OfferItem上创建商品集时,我将offerItem添加到商品的OfferItems列表上,然后保存商品。我可以看到offerItem id是如何生成的,因为它在级联上保持不变。但是offerItem和item之间的链接丢失了。

我只是尝试在OfferItem上设置项目,并使用他自己的服务保存实体,但是什么也没有。我无法在他们之间保持这种联系。

任何想法或建议。

问候。

最佳答案

从联接列中删除insertable = false, updatable = false。另外,offerItems的映射是错误的。它应该是

@OneToMany(orphanRemoval = true, cascade = {CascadeType.ALL}, mappedBy = "offer")
@XmlElementWrapper
@Getter
private List<OfferItem> offerItems = new ArrayList<>();

08-18 05:37