拖轮公司的船舶基本信息和拖轮计划之间是多对多的关系。
@ManyToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE }, fetch = FetchType.EAGER) @JoinTable(name = "PB18_PlAN_SHIPINFO", joinColumns = { @JoinColumn(name = "tpId") }, inverseJoinColumns = { @JoinColumn(name = "tsId") }) private List<TugShipInfo> tugShipInfos = new ArrayList<TugShipInfo>();;// 拖轮公司船舶基本信息@ManyToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE }, fetch = FetchType.LAZY, mappedBy = "tugShipInfos") private List<TugPlan> tugPlans = new ArrayList<TugPlan>();
@ManyToOne Default: FetchType.EAGER 默认是即时抓取 做连接 如果,fetch=FetchType.LAZY不是左联接 在需要One的时候直接select @OneToMany Default: FetchType.LAZY 默认是延迟抓取 不需要左联接 如果是FetchType.EAGER 即时抓取 就会是左联接查询 @ManyToMany Default: FetchType.LAZY 默认是延迟抓取 不需要左联接 如果是FetchType.EAGER 即时抓取 就会是左联接查询
cascade的值只能从CascadeType.PERSIST(级联新建)、CascadeType.REMOVE(级联删除)、CascadeType.REFRESH(级联刷新)、CascadeType.MERGE(级联更新)中选择一个或多个。还有一个选择是使用CascadeType.ALL,表示选择全部四项。