Hibernate关联关系笔记
* 有连接表:在N方使用<join>/<many-to-one>。1方无需配置与之关联的持久化类。
* 没有连接表:在N方使用<many-to-one>。1方无需配置与之关联的持久化类。
* 有连接表: 在1方使用<set>/<many-to-many>,在many-to-many中将unique属性设置为true。 N方无需配置与之关联的持久化类。
* 没有连接表:在1方使用<set>/<one-to-many>。N方无需配置与之关联的持久化类。
注:cascade属性在<set>上配置
* 有连接表:1方使用<set>/<many-to-many>并设置<many-to-many>的unique参数为true。N方使用<join>/<many-to-one>
* 没有连接表:1方使用<set>/<one-to-many>。N方使用<many-to-one>
注:只能在1的一方使用inverse放弃控制权,N的一方无法放弃控制权,因为没有inverse属性。
控制端使用<set>/<many-to-many>
两边都使用<set>/<many-to-many>
* 基于外键:控制端使用<many-to-one>,并设置<many-to-one>的unique属性为true。
* 基于主键:控制端设置ID生成策略为foreign,并使用<one-to-one>标签。
* 基于连接表:控制端使用<join>/<many-to-one>,并设置<many-to-one>的unique属性为true
* 基于外键:一方使用<many-to-one>并设置其unique参数为true。另一方使用<one-to-one>
* 基于主键:一方设置ID生成策略为foreign,并使用<one-to-one>标签。另一方只使用<one-to-one>标签。
* 基于连接表:两边都使用<join>/<many-to-one>。并都设置<join>下的<key>unique属性和<many-to-one>的unique属性为true。而且两边需要有一边设置inverse参数为true,即放弃控制权。
新闻热点
疑难解答