hibernate的一对多映射可以通过几种方式实现,这里介绍通过set来实现的方法(可以参考前面的set,list,map映射)
这里,我为该映射构建两个类Room和Resident,标志代码如下:
public class Room {
private int roomNum;
private String address;
private Set residents = new HashSet();
}
public class Resident {
private int id;
private String name;
}
通过Room中的residents,我们将在一个Room对应的表象中存储多个Resident的数据。
对应的Resident.hbm.xml很简单
<id name= "id" column= "id" unsaved-value= "0" >
<generator class= "increment" />
<!-- why must be increment -->
</id>
同其他持久化类不同的是,只要声明unsaved-value就可以在Resident类中实现联级的存储。至于为什么要unsaved-value= "0" ,建议你去前面几篇基础看一下相应的解释
比较重要的是Room.hbm.xml,因为它包含了有关set映射及联级等的描述。Room.hbm.xml中重要部分如下
<set name= "residents" table= "resident" order-by= "id desc"
cascade= "all" inverse= "false" >
<key column= "roomNum" />
<one-to-many class= "onetomany.Resident" />
</set>
在set的描述中,order-by= "id desc"对应了加入set中的Resident是按照id降序排列的,在Resident对应的表中可以清楚地看到。cascade= "all" 说明任何针对Room的操作都会对相应的Resident起作用。inverse= "false" 则说明了这里的联级要交给Room而不是Resident来处理。
<one-to-many class= "onetomany.Resident" />
这句是区别与set映射最大的地方。说明了对应于“多”这一项的类。
执行的时候,只要存储Room即可实现相应的联级存储
session.save(room);
看完了以上介绍,想必应该对一对多映射有了一定的初步了解。其实这个一对多的例子还不是很好,因为始终不能将“多”这一类的id改为asignment,否则会出现存储错误。如果哪位解决了,或者知道这是为什么,请恢复一下,呵呵,还请指点。