您的位置:首页 > 数据库

hibernate基础_3

2005-05-17 10:43 316 查看
本篇是关于inheritedmapping的。关于inheritedmapping,在hibernate中有几种实现方式。今天先讲述一个,即将父子对象存入同一个数据库中以及相应的实现。
设计这样一个关系:user和administrator。administrator是user的一个子类,其中不但包括了从user中继承的id,password和name,也有自己的属性level。
两个类的代码如下
public class User {
    private int id;
    private String password;
    private String name;
}
public class Administrator extends User {
    private int level;
}
根据hibernate的特性,关键问题还是在配置文件上。这个父子影射的实现只要一个父类的配置文件User.hbm.xml。下面,我只挑选重要行来解释,其他的诸如property等就不再冗述了
<class name= "User" table= "LevelUser"
    discriminator-value= "USER" >
同其他的.hbm.xml文件相同,在<hibernate-mapping>后紧跟的是上面那条语句。可是不同于其他的,其中多出了discriminator-value= "USER" 这句。这句表明了在数据库中的UserType列(后面详述这个重要的列)中,user类对应的数据为USER
<discriminator column= "UserType" type= "string" />
这个便是表明父子关系的列。discriminator同discriminator-value相对应,说明了各类的标示在table中是如何存储的。
 <subclass name= "Administrator" discriminator-value= "ADMIN" >
      <property name= "level" type= "integer" column= "Level" />
</subclass>
这个便是子类的映射标示了。有了上面user的discriminator-value解释,你应该很容易就看明白这段代码了吧
可以按如下方法进行查询:
List users = session.find( "from Administrator" );
这样,users中存储的就是全部数据库中的administrator了。如果想对全部的user进行查询,将"from Administrator"换成"from User"就可以了。
父子映射的存储于其他方式的存储方式相同,不另外介绍了。
下一篇介绍hibernate的另外一种父子映射。
to be continued...
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息