在ManyToOne Relationship的Many侧创建实体的实例

时间:2017-09-02 14:58:49

标签: java hibernate orm spring-data-jpa hibernate-onetomany

我正在使用 Spring Data JPA 我有以下实体

实体

class Person{

private String id;

@OneToMany(mappedBy="owner")
private List<Contact> contacts;
...

}

联系实体

class Contact{

private String id;

@ManyToOne
@JoinColumn(name="owner_id")
private Person owner;
...

}

当我想创建Contact实例时,我对如何映射所有者详细信息感到困惑。

Contact contact = new Contact();
contact.setOwner(?);

但是在创作时我只会拥有owner_id 我想在创建时单独设置owner_id,但要有关联(在查询时)我已将其映射到具体类(Person)。

我试过这个

class Contact{

@Column("owner_id")
private String ownerId;
@ManyToOne
@JoinColumn("owner_id")
private Person pwner;

} 

但是它的抛出错误重复了对owner_id的引用。

我不想用owner_id查询Person Table并设置&#34; Person&#34;创建联系人时参考设置。

我想在插入和所有者引用时使用owner_id,我可以通过该引用获取给予联系人的所有者详细信息。 如何解决这个问题。

先谢谢。

2 个答案:

答案 0 :(得分:0)

您需要一位用户。此用户位于数据库中。 JPA允许将数据库表的行映射到实体。您拥有此用户的ID。所以......让用户使用JPA API:

contact.setOwner(entityManager.find(User.class, userId));

contact.setOwner(entityManager.getReference(User.class, userId));

第一个实际上从数据库中获取用户的详细信息,从而检查用户是否确实存在。

第二个假定用户存在,ans只创建一个延迟初始化的代理,而不查询数据库。

答案 1 :(得分:0)

class Person {

   private String id;

   @OneToMany(mappedBy="owner")
   private List<Contact> contacts;

}

class Contact {

   private String id;

   @ManyToOne(fetch = FetchType.Lazy)
   @JoinColumn(name="owner_id", nullable=false,updatable=false)
   private Person owner;

   @Column("owner_id")
   private String ownerId;

}

这实际上允许我在创建联系人对象时使用ownerId:String字段,owner:Owner对象帮助我获取给定联系人详细信息的所有者详细信息(如果需要)。这样我就可以达到我的要求不使用findOne(id)getOne(id)