hibernate基础_3

发表于:2007-07-01来源:作者:点击数: 标签:
本篇是关于inheritedmapping的。关于inheritedmapping,在hibernate中有几种实现方式。今天先讲述一个,即将父子对象存入同一个 数据库 中以及相应的实现。 设计这样一个关系:user和administrator。administrator是user的一个子类,其中不但包括了从user中
 

本篇是关于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...

原文转自:http://www.ltesting.net