浅析Java的Hibernate框架中的继承关系设计
这次我们来说一下hibernate的层次设计,层次设计也就是实体之间的继承关系的设计。 public class TItem implements Serializable{ //省略Get/Set方法 private int id; private String manufacture; private String name; } public class TBook extends TItem{ //省略Get/Set方法 private int pageCount; } public class TDVD extends TItem{ //省略Get/Set方法 private String regionCode; } <class name="TItem" table="ITEM"> <id name="id" column="id" type="java.lang.Integer"> <generator class="native" /> </id> <property name="name" column="name" type="java.lang.String"/> <property name="manufacture" column="manufacture" type="java.lang.String"/> </class> <class name="TBook" table="Book"> <id name="id" column="id" type="java.lang.Integer"> <generator class="native" /> </id> <property name="name" column="name" type="java.lang.String"/> <property name="manufacture" column="manufacture" type="java.lang.String"/> <property name="pageCount" column="pageCount" type="java.lang.Integer"/> </class> <class name="TDVD" table="DVD"> <id name="id" column="id" type="java.lang.Integer"> <generator class="native" /> </id> <property name="name" column="name" type="java.lang.String"/> <property name="manufacture" column="manufacture" type="java.lang.String"/> <property name="regionCode" column="regionCode" type="java.lang.String"/> </class> 很普通的映射文件,跟以前的没什么区别。 public void testSelect() { Query query = session.createQuery("from TItem "); List list = query.list(); Iterator iter = list.iterator(); while(iter.hasNext()) { System.out.println("Name:"+(((TItem)iter.next()).getName())); } } 注意,这里我们是用TItem类,而不是具体的字类,这里它会自动去查找继承于TItem类的子类,查出所有结果。这里涉及到一个多态模式,class标签有属性 polymorphism,它的默认值为implicit,这意味着不需要指定名称就可以查询出结果。如果为explicit则表明需要指定具体的类名时,才可以查出此类的结果。 <class name="TItem" table="ITEM" polymorphism="explicit"> <id name="id" column="id" type="java.lang.Integer"> <generator class="native" /> </id> <property name="name" column="name" type="java.lang.String"/> <property name="manufacture" column="manufacture" type="java.lang.String"/> <joined-subclass name="TBook" table="TBOOK"> <key column="id" /> <property name="pageCount" column="pageCount" type="java.lang.Integer" /> </joined-subclass> <joined-subclass name="TDVD" table="TDVD"> <key column="id"/> <property name="regionCode" column="regionCode" type="java.lang.String"/> </joined-subclass> </class> 两个子类对应的表只有我们通过property指定的字段。这样就避免了表内有多个字段,使字表只维护其单独字段,当item类进行改变时,也不用过多的进行修改。 3)再来了解另外一种方法实现层次设计,这就是通过在表内置入标志来实现。在hibernate的映射文件中我们通过descriminator标签来进行实现。 <class name="TItem" table="ITEM" polymorphism="explicit"> <id name="id" column="id" type="java.lang.Integer"> <generator class="native" /> </id> <discriminator column="category" type="java.lang.String"/> <property name="name" column="name" type="java.lang.String"/> <property name="manufacture" column="manufacture" type="java.lang.String"/> </class> 看到中间,我们加入了一个discriminator标签,它表明我们以下的两个subclass通过哪个字段来进行区别。 <subclass name="TBook" discriminator-value="1"> <property name="pageCount" column="pageCount"/> </subclass> <subclass name="TDVD" discriminator-value="2" > <property name="regionCode" column="regionCode"/> </subclass> 我们看到这两段,它指明了当discriminator所指定的field的值为1时,表明它是TBook类,并且pageCount有值;当discriminator所指定的field值为2时,表明它是TDVD类,并且regionCode有值。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |