1.双向多对多拆分,一对多设置方法
- 两个一对多
-增加中间表(为多端)
一端:
// a
@OneToMany(mappedBy="autoMakerDetail", fetch = FetchType.EAGER)
private Set<AutosSmallClassesMiddle> autosSmallClassesMiddleSet = new HashSet<AutosSmallClassesMiddle>();
// b
@OneToMany(mappedBy="smallClass", fetch = FetchType.EAGER)
private Set<AutosSmallClassesMiddle> autosSmallClassesMiddleSet = new HashSet<AutosSmallClassesMiddle>();
多端:
// 新建对应项时,通过多端dao新建
@ManyToOne(cascade={CascadeType.MERGE}, fetch = FetchType.EAGER)
@JoinColumn(name="smallClassId")
private SmallClass smallClass = null;
@ManyToOne(cascade={CascadeType.MERGE}, fetch = FetchType.EAGER)
@JoinColumn(name="autoMakerDetailId")
private AutoMakerDetail autoMakerDetail = null;
2.懒抓取fetch策略,获取值no session,fetch = FetchType.EAGE
3.hibernate查询是基于对象的
public List<AutosSmallClassesMiddle> findByAutoMakerDetail(final AutoMakerDetail autoMakerDetail) {
return this.getEntityManager()
.createQuery("from AutosSmallClassesMiddle as obj where obj.autoMakerDetail=:amd")
.setParameter("amd", autoMakerDetail).getResultList();
}
4.MERGE级联方式
cascade={CascadeType.MERGE}
当出现外键时,外键所指对象可以预先建立。
若为ALL,可以在新建子对象时自动创建父对象。