基于注解的domain

现在的需求是省份和城市是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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值