1.在hibernate中继承映射的三种方式 SINGLE_TABLE,TABLE_PER_CLASS,JOINED
2. SINGLE_TABLE第一种方式
3. 我们以Person,Student,Teacher类来举例说明(Person是父类,其余两个是子类)
4.在Person父类中
5.其他两个子类中
6.生成表之后,我们会发现父类和子类的表是放在一块的。
7.TABLE_PER_CLASS的第二种方式
8.在父类Person中
9.在其他两个子类中只需要写上@Entity这个注解就可了
10.生成表我们可以看出数据库生成四张表
11.Joined第三种方式
12.Person父类中
13.其他两个类中,也是只需要@Entity注解即可。
14.生成表中,我们发现生成了三张表,person表,student表,teacher表。
15.附上测试代码如下:
package com.zhlk.model;
import java.util.Date;
import java.util.Map;
import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.metamodel.relational.Schema;
import org.hibernate.sql.QuerySelect;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
/**
* @author lvguanghui date 2017-1-21
*/
public class HibernatORmappingTest {
private static SessionFactory sf = null;
@BeforeClass
public static void beforeClass() {
new SchemaExport(new AnnotationConfiguration().configure()).create(true, true);
sf = new AnnotationConfiguration().configure().buildSessionFactory();
}
@AfterClass
public static void afterClass() {
sf.close();
}
@Test
public void testUserSave() {
Student s=new Student();
s.setName("s1");
s.setScore(90);
Teacher t=new Teacher();
t.setName("t1");
t.setTitle("titleT1");
Session session = sf.getCurrentSession();
session.beginTransaction();
session.save(s);
session.save(t);
session.getTransaction().commit();
}
public static void main(String[] args) {
beforeClass();
}
}