标签:区分 上进 actor 数据库 blog 主键 log 注意 person
1 简单继承映射,在子类上进行映射配置,可以将父类属性直接配置在子类映射文件中。
简单例子如下:teacher类继承自Person类。
public class Person { private int id; private String pname; public Person() { // TODO Auto-generated constructor stub } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getPname() { return pname; } public void setPname(String pname) { this.pname = pname; } }
Teacher
public class Teacher extends Person { private String tschoolName; public Teacher() { // TODO Auto-generated constructor stub } public String getTschoolName() { return tschoolName; } public void setTschoolName(String tschoolName) { this.tschoolName = tschoolName; } }
Teacher.hbm.xml配置文件
<hibernate-mapping package="com.baidu.entity3"> <class name="Teacher" table="teacher"> <id name="id" column="id"> <generator class="native"></generator> </id> <property name="pname" column="name"></property> <property name="tschoolName" column="schoolName"></property> </class> </hibernate-mapping>
简单测试
public void fun1(){ Teacher teacher = new Teacher(); teacher.setPname("good"); teacher.setTschoolName("南洋理工"); Configuration configuration = new Configuration(); configuration.configure(); SessionFactory sessionFac = configuration.buildSessionFactory(); Session session = sessionFac.openSession(); Transaction bt = session.beginTransaction(); session.save(teacher); bt.commit(); session.close(); sessionFac.close(); }
2 所有类使用一张表,使用subclass属性。注意需要使用类鉴别器,这种设计方法不太符合数据库表的设计原则,会用很多空的字段产生。
继续上面的例子,新产生一个类,Engineer
public class Engineer extends Person { private String ecompName; public Engineer() { // TODO Auto-generated constructor stub } public String getEcompName() { return ecompName; } public void setEcompName(String ecompName) { this.ecompName = ecompName; } }
此时配置文件只在父类Person.hbm.xml映射文件中做
<hibernate-mapping package="com.baidu.entity3"> <class name="Person" table="person"> <id name="id" column="id"> <generator class="native"/> </id> <discriminator column="type"></discriminator> <property name="pname" column="name"></property> <subclass name="Teacher" discriminator-value="teacher_"> <property name="tschoolName" column="schoolName"></property> </subclass> <subclass name="Engineer" discriminator-value="engineer_"> <property name="ecompName" column="eompanyName"></property> </subclass> </class> </hibernate-mapping>
注意需要使用鉴别器,discriminator位置在id属性下面,property上面。每个子类使用subclass标签区分,需要指定discriminator-value属性,表明该类属于那个类别。
3 每个类使用一张表,属性关键字joined-subclass,也是在父类的配置文件上Person.hbm.xml配置
<hibernate-mapping package="com.baidu.entity3"> <class name="Person" table="person"> <id name="id" column="id"> <generator class="native"/> </id> <discriminator column="type"></discriminator> <property name="pname" column="name"></property> <joined-subclass name="Engineer" table="engineer"> <key column="id"></key> <property name="ecompName" column="companyName"></property> </joined-subclass> <joined-subclass name="Teacher" table="teacher"> <key column="id"></key> <property name="tschoolName" column="schoolName"></property> </joined-subclass> </class> </hibernate-mapping>
注意:因为每个子类都要生成一张表,因此在使用joined-subclass的时候需要指定table属性来指定使用那张表。
4 所有子类使用一张表,属性关键字union-subclass。注意这种方式主键的生成方式不可以使用自增长,可以使用uuid。配置文件还是在Person.hbm.xml配置
<hibernate-mapping package="com.baidu.entity3"> <class name="Person" table="person"> <id name="id" column="id"> <generator class="uuid"/> </id> <discriminator column="type"></discriminator> <property name="pname" column="name"></property> <union-subclass name="Engineer" table="engineer"> <property name="ecompName" column="companyName"></property> </union-subclass> <union-subclass name="Teacher" table="teacher"> <property name="tschoolName" column="schoolName"></property> </union-subclass> </class> </hibernate-mapping>
标签:区分 上进 actor 数据库 blog 主键 log 注意 person
原文地址:http://www.cnblogs.com/zhaopengcheng/p/6774694.html