如果我们不在OneToMany注释中指定mappedBy属性怎么办?

时间:2014-07-05 08:12:11

标签: java hibernate jpa

这些天我正在用hibernate学习JPA。我无法理解为什么如果未指定mappedBy属性,hibernate会为双向OnetoMany关系提供错误。以下是我收到错误的代码:

@Entity
public class Item {
    @Id
    private long id;
    private String name;
    private String description;
   @OneToMany()
    Set<Bid> bids = new HashSet<Bid>();

Bid是ITEM的子实体

@Entity(name="BIDS")
public class Bid {
    @Id
    @Column(name="BID_ID")
    private Long id;    
    private Double amount;  
    @ManyToOne
    @JoinColumn(name="ITEM_ID")
    Item item;

在主课程中,我正在保存父实体和子实体:

Transaction transaction = session.beginTransaction();
        Item item = new Item();
        item.setId(111);
        item.setDescription("ITEM Description");
        item.setName("Name1");
        Bid bid = new Bid();
        bid.setId(21l);
        bid.setAmount(1.1);
        bid.setItem(item);
        Set<Bid> bids = new HashSet<Bid>();
        bids.add(bid);
        item.setBids(bids);
        session.save(item);
        session.save(bid);
        transaction.commit();

但是hibernate尝试执行以下查询并抛出ITEM_BIDS表不存在。

Hibernate: insert into Item (description, name, id) values (?, ?, ?)
Hibernate: insert into BIDS (amount, ITEM_ID, BID_ID) values (?, ?, ?)
Hibernate: insert into Item_BIDS (Item_id, bids_BID_ID) values (?, ?)

请告诉我为什么hibernate会产生额外的查询以及mappedBy元素将如何解决这个问题。

1 个答案:

答案 0 :(得分:6)

因为如果你没有指定mappedBy,你不是说OneToManyItem之间的BidManyToOne之间Bid 1}}和Item实际上是唯一双向关联的两个方面。

因此Hibernate认为它们是两个不同的单向关联。由于OneToMany关联的默认映射是使用连接表,这就是Hibernate使用的。