之旅(四)"/>
SSH——Hibernate初学者之旅(四)
之前我们说到了一对一和一对多关系的几种映射类型,最后只剩下多对多关系的映射。一般来讲,我们会将多对多关系抽出第三张表,转化为一对多关系,但是难免会有一些特殊情况。今天我们就来看看多对多关系的映射。
一、单向多对多
1、实体
一个人可对应多个地址,一个地址也可以对应多个人。
//人
public class Personnn {private int personid;private String name;private int age;//可以设置多个地址private Set addresses=new HashSet();
//地址
public class Addressnn {private int addressid;private String addressdetail;
2、映射关系实现
<hibernate-mapping><class name="com.lavasoft.dx._n_n.Personnn" table="PERSON_nn"><id name="personid"><generator class="identity"/></id><property name="name"/><property name="age"/><!--映射集合属性,join_1ntab是连接表表名--><set name="addresses"table="join_nn"><!--“column="personid"”确定PERSON_1ntab表关联到连接表的外键列名--><key column="personid"/><!--“column="addressid"”关联PERSON_1ntab表的Address1ntab对象的id在连接表中的列名--><many-to-many
column="addressid"class="com.lavasoft.dx._n_n.Addressnn"/></set></class>
</hibernate-mapping>
<hibernate-mapping><class name="com.lavasoft.dx._n_n.Addressnn" table="ADDRESS_nn"><id name="addressid"><generator class="identity"/></id><property name="addressdetail"/></class>
</hibernate-mapping>
二、双向多对多
1、实体
//人
public class Personnn {private int personid;private String name;private int age;//可以设置多个地址private Set addresses=new HashSet();
public class Addressnn {private int addressid;private String addressdetail;private Set persons = new HashSet();
2、映射关系实现
<hibernate-mapping><class name="com.lavasoft.sx._n_n.Personnn_sx" table="PERSON_nn_sx"><id name="personid"><generator class="identity"/></id><property name="name"/><property name="age"/><!--映射集合属性,关联到持久化类--><!--table="join_1ntab_sx"指定了连接表的名字--><set name="addresses"table="join_nn_sx"cascade="all"><!--column="personid"指定连接表中关联当前实体类的列名--><key column="personid" not-null="true"/><!--column="addressid"是连接表中关联本实体的外键--><many-to-many column="addressid"class="com.lavasoft.sx._n_n.Addressnn_sx"/></set></class>
</hibernate-mapping>
<hibernate-mapping><class name="com.lavasoft.sx._n_n.Addressnn_sx"table="ADDRESS_nn_sx"><id name="addressid"><generator class="identity"/></id><property name="addressdetail"/><!--table="join_nn_sx"是双向多对多的连接表--><set name="persons"inverse="true"table="join_nn_sx"><!--column="addressid"是连接表中关联本实体的外键--><key column="addressid"/><many-to-many column="personid"class="com.lavasoft.sx._n_n.Personnn_sx"/></set></class>
</hibernate-mapping>
总结:
至此,我们将hibernate中常用的几种映射关系已经学习了,至于其他的如继承关系等,这里就不在一一赘述了,我们学习不仅仅停留于此,这只是开了一个头,所以,我们还需要结合实际情况,继续深入学习。
更多推荐
SSH——Hibernate初学者之旅(四)
发布评论