动物Animal为基类,Pig和Bird为子类,他们之间存在继承关系。这里我们来演示每个类一张表的映射。
类图:
映射出的数据库表:
Animal.java:
public class Animal { private int id; private String name; private boolean sex; //省略setter和getter方法 }
Bird.java:
public class Bird extends Animal { private int height; //省略setter和getter方法 }
Pig.java:
public class Pig extends Animal { private int weight; //省略setter和getter方法 }
映射文件Extends1.hbm.xml:
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.lixue.bean"> <class name="Animal" table="t_animal" lazy="false"> <id name="id"> <generator class="native" /> </id> <property name="name" /> <property name="sex"/> <!-- 通过joined-subclass来映射子类 --> <joined-subclass name="Pig" table="t_pig"> <key column="pid"/> <property name="weight"/> </joined-subclass> <joined-subclass name="Bird" table="t_bird"> <key column="bid"/> <property name="height" /> </joined-subclass> </class> </hibernate-mapping>
测试类:
public void testSave(){ /*定义Session和事物*/ Session session = null; Transaction transaction = null; try { /*获取Session并开启事物*/ session = HibernateUtils.getSession(); transaction = session.beginTransaction(); /*创建Pig对象并设置属性*/ Pig pig = new Pig(); pig.setName("小猪"); pig.setSex(true); pig.setWeight(200); session.save(pig); /*创建Bird对象并设置属性*/ Bird bird = new Bird(); bird.setName("小鸟"); bird.setSex(false); bird.setHeight(100); session.save(bird); /*提交事物*/ transaction.commit(); } catch (Exception e) { e.printStackTrace(); transaction.rollback(); } finally{ HibernateUtils.closeSession(session); } }
查询方法:
public void testLoad() { Animal animal = (Animal) HibernateUtils.getSession().get(Animal.class, 1); if (animal instanceof Pig){ System.out.println("猪:" + animal.getName()); } else { System.out.println("不是猪!"); } }
注:虽然表面上看起来查询出的对象的类型为Animal,其实Hibernate为此做了优化,非常智能,ID对应的对象是什么类型,查出来的对象就是什么类型,如上述程序,假设ID为1时的记录为Pig对象,那么上述程序输出的结果应该为:"猪 :XXX",因为animal
instanceof Pig 为true。
注:
每个类一张表是采用joined-subclass标签来定义子类的。父类、子类每个子类都对应一个数据库表。在父类对应的数据库表中,实际上会存储所有的记录,包括父类和子类的记录;在子类对应的数据库表中只定义了子类中所特有的属性映射的字段。子类与父类,通过相同的主键来关联。
实现步骤:
1.父类用普通的<class>标签来定义即可,不需要定义区分字段。
2.子类用<join-subclass>标签定义。另外因为每个子类都对应一张表,然而这些子类是没有主键的,所以要自己指定主键,通过<key>字段来知道指定主键如:<key
column="XXX">