我正在使用 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,我可以通过该引用获取给予联系人的所有者详细信息。 如何解决这个问题。
先谢谢。
答案 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)
。