📅  最后修改于: 2021-01-02 13:42:36             🧑  作者: Mango
如果使用Table Per Concrete类,则数据库中将存在三个彼此无关的表。有两种方法可以将表与每个具体类策略的表进行映射。
让我们了解我们要映射的层次结构。
让我们看看如何通过union-subclass元素映射此层次结构:
对于每个具体类的表,数据库中将有三个表,每个表代表一个特定的类。 class的union-subclass子元素指定子类。它将父表的列添加到该表中。换句话说,它正在作为工会。
每个表的表结构如下:
在此示例中,我们将创建三个类,并在employee.hbm.xml文件中提供这些类的映射。
您需要创建代表继承的持久类。让我们为上述层次结构创建三个类:
package com.javatpoint.mypackage;
public class Employee {
private int id;
private String name;
//getters and setters
}
package com.javatpoint.mypackage;
public class Regular_Employee extends Employee{
private float salary;
private int bonus;
//getters and setters
}
package com.javatpoint.mypackage;
public class Contract_Employee extends Employee{
private float pay_per_hour;
private String contract_duration;
//getters and setters
}
上面已经针对层次结构讨论了映射。
打开hibernate.cgf.xml文件,并添加如下所示的映射资源条目:
现在配置文件将如下所示:
update
org.hibernate.dialect.Oracle9Dialect
jdbc:oracle:thin:@localhost:1521:xe
system
jtp
oracle.jdbc.driver.OracleDriver
定义了hbm2ddl.auto属性,用于在数据库中创建自动表。
在此类中,我们仅将雇员对象存储在数据库中。
package com.javatpoint.mypackage;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
public class StoreData {
public static void main(String[] args) {
StandardServiceRegistry ssr=new StandardServiceRegistryBuilder().configure("hibernate.cfg.xml").build();
Metadata meta=new MetadataSources(ssr).getMetadataBuilder().build();
SessionFactory factory=meta.getSessionFactoryBuilder().build();
Session session=factory.openSession();
Transaction t=session.beginTransaction();
Employee e1=new Employee();
e1.setName("Gaurav Chawla");
Regular_Employee e2=new Regular_Employee();
e2.setName("Vivek Kumar");
e2.setSalary(50000);
e2.setBonus(5);
Contract_Employee e3=new Contract_Employee();
e3.setName("Arjun Kumar");
e3.setPay_per_hour(1000);
e3.setContract_duration("15 hours");
session.persist(e1);
session.persist(e2);
session.persist(e3);
t.commit();
session.close();
System.out.println("success");
}
}