现在的需求是省份和城市是1对多的单项,城市和地区是一对多的单项
现在省的代码结构:
private Set<City> citys = new HashSet<City>();
/**
* 省与城市单向 一对多
*
* @return
*/
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name = "pro_id")
public Set<City> getCitys() {
return citys;
}
这样的话,在城市的表中就多了一个pro_id的字段
在这里没有比较去做双向,所以在城市的代码中就没有省的属性
如果想要做双向关联,那么代码结构:
private Set<City> citys = new HashSet<City>();
/**
* 省与城市双向 一对多
*
* @return
*/
@OneToMany(mappedBy="province")
public Set<City> getCitys() {
return citys;
}
mappedBy 只能是OneToMany 和 ManyToMany中有,在ManyToOne中没,这个属性主要就是用于双向关联配置的
private Province province;
@ManyToOne(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name = "pid")
public Province getProvince() {
return province;
}
这样数据库中依然只是在城市的表中增加一个pid字段,但是在程序中就可以用过城市来操作所属的省份
关于城市和地区
地区是一个值类型,不能用oneToMany来表示,只能用一下方式
@CollectionOfElements(fetch = FetchType.EAGER)
@JoinTable(name = "cityarea", joinColumns = { @JoinColumn(name = "city_id") })
@Column(name = "cityArea")
public Set<String> getCityAreas() {
return cityAreas;
}
table cityarea
column city_id , cityArea