嗨,我有一个实体
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<>();