同一对多映射相对应,hibernate也提供多对一的映射。 为了实现多对一映射,我构建了下面两个样例类 public class Resident2 { private int id; private String name; private Room2 room; } public class Room2 { private int roomNum; private String address; } 可以看到,这里Resident2同Room2是多对一的关系,而这种关系是通过在每一个Resident2对象中持有一个Room2的引用来实现的。这里,用到的数据表同"hibernate基础_6"中用到的相同。 Room.hbm.xml描述符很简单 <id name= "roomNum" column= "roomNum" unsaved-value= "0" > <generator class= "increment" /> <!--why must be increment--> </id> 唯一值得注意的是unsaved-value= "0" 这句,由于要实现联级操作,所以必须得对Room的id赋值。至于为什么赋为0,大家可以参考前面的hibernate基础。 Resident.hbm.xml就比较复杂了 <many-to-one name= "room" column= "roomNum" class= "manytoone.Room2" cascade= "all" /> 其实复杂也就是多出了这么一句话。cascade说明我们需要对该映射进行联级操作。至于谁是主操作方,可以通过inverse来说明。这里没有写出,因为狠明显是要操作Resident2来实现对Room2的存储与更新。如果要写,加入inverse= "false" ,即代表Resident2为主操作方。 其他的属性描述就不再冗述了 在客户端,我们如此调用 Room2 r1 = new Room2(); r1.setAddress("minhang.sjtu.D23"); Resident2 res1 = new Resident2(); res1.setId(120); res1.setName("D"); res1.setRoom(r1);
//res2, res3的声明类似于res1 session.save(res1); session.save(res2); session.save(res3); 及实现了联级存储。相信有了"hibernate基础_6"作为参考,这篇文章应该不会很难理解 不过,同"hibernate基础_6",我同样有个问题,就是Room2的id为什么必须是increment才可以联级存储成功(在我的机器上是这样的),这样局限性太大了吧。肯定是我哪里没弄好,还请了解的达人给我留个言,解答一下。 
|