hibernate 4.3
hibernate默认的描述关系是创建一个关联表, 根据sql打印, 每次修改bed, 都会将关联表的记录删除再逐个添加.
而关联关系添加 @JoinColumn(name="dorm_id")后, 不再生成关联表,而是通过字段dorm_id关联, 更新删除bed的效率高很多,但是在维护关系的时候, bed需要手动设置dorm,
这个是多一个操作的地方.
设置orphanRemoval=true一大好处, 当dorm中的bed记录被删除(dorm的数据有前台提交),保存dorm时, hibernate会自动的同步数据库, 这下就省事多了
mappedBy="dorm" 关联到多端的dorm属性,利用dorm属性进行关联.与添加@JoinColumn(name="dorm_id") 有相同的功效
// 宿舍, 一端
public class Dorm {
@Id
@GeneratedValue
private Long id;
// 宿舍名称
@NotBlank
private String name;
// 住宿人数
@NotNull
private Integer stayCount;
// 床位
@OneToMany(fetch=FetchType.LAZY, cascade=CascadeType.ALL, orphanRemoval=true, mappedBy="dorm")
// @JoinColumn(name="dorm_id")
private List<Bed> beds = new ArrayList<Bed>();
...
}
// 床位, 多端
public class Bed {
@Id
@GeneratedValue
private Long id;
// 床位
@NotBlank
private String number;
// 宿舍
@ManyToOne
// @JoinColumn(name="dorm_id")
@JsonIgnore // json数据获取的时候要JsonIgnore加忽略dorm属性,因为dorm.getBed(),获取床位属性, 如果在bed.getDorm()再获取属性, 就会形成死循环
private Dorm dorm;
...
}
hibernate默认的描述关系是创建一个关联表, 根据sql打印, 每次修改bed, 都会将关联表的记录删除再逐个添加.
而关联关系添加 @JoinColumn(name="dorm_id")后, 不再生成关联表,而是通过字段dorm_id关联, 更新删除bed的效率高很多,但是在维护关系的时候, bed需要手动设置dorm,
public void saveOrUpdate(Dorm dorm){
for(Bed bed : dorm.getBeds()){
bed.setDorm(dorm);
}
dormDao.save(dorm);
}
这个是多一个操作的地方.
设置orphanRemoval=true一大好处, 当dorm中的bed记录被删除(dorm的数据有前台提交),保存dorm时, hibernate会自动的同步数据库, 这下就省事多了
mappedBy="dorm" 关联到多端的dorm属性,利用dorm属性进行关联.与添加@JoinColumn(name="dorm_id") 有相同的功效