Table Per Subclass using Annotation

As we have specified earlier, in case of table per subclass strategy, tables are created as per persistent classes but they are reated using primary and foreign key. So there will not be duplicate columns in the relation.
We need to specify @Inheritance(strategy=InheritanceType.JOINED) in the parent class and @PrimaryKeyJoinColumn annotation in the subclasses.
Let's see the hierarchy of classes that we are going to map.
table per subclass strategy
The table structure for each table will be as follows:

Table structure for Employee class

table per subclass class

Table structure for Regular_Employee class

table per subclass class

Table structure for Contract_Employee class

table per subclass class

Example of Table per subclass class using Annotation

In this example we are creating the three classes and provide mapping of these classes in the employee.hbm.xml file.

1) Create the Persistent classes

You need to create the persistent classes representing the inheritance. Let's create the three classes for the above hierarchy:
File: Employee.java
  1. package com.javatpoint.mypackage;  
  2. import javax.persistence.*;  
  3.   
  4. @Entity  
  5. @Table(name = "employee103")  
  6. @Inheritance(strategy=InheritanceType.JOINED)  
  7.   
  8. public class Employee {  
  9. @Id  
  10. @GeneratedValue(strategy=GenerationType.AUTO)  
  11.       
  12. @Column(name = "id")  
  13. private int id;  
  14.   
  15. @Column(name = "name")  
  16. private String name;  
  17.   
  18. //setters and getters  
  19. }  
File: Regular_Employee.java
  1. package com.javatpoint.mypackage;  
  2.   
  3. import javax.persistence.*;  
  4.   
  5. @Entity  
  6. @Table(name="regularemployee103")  
  7. @PrimaryKeyJoinColumn(name="ID")  
  8. public class Regular_Employee extends Employee{  
  9.       
  10. @Column(name="salary")    
  11. private float salary;  
  12.   
  13. @Column(name="bonus")     
  14. private int bonus;  
  15.   
  16. //setters and getters  
  17. }  
File: Contract_Employee.java
  1. package com.javatpoint.mypackage;  
  2.   
  3. import javax.persistence.*;  
  4.   
  5. @Entity  
  6. @Table(name="contractemployee103")  
  7. @PrimaryKeyJoinColumn(name="ID")  
  8. public class Contract_Employee extends Employee{  
  9.       
  10.     @Column(name="pay_per_hour")  
  11.     private float pay_per_hour;  
  12.       
  13.     @Column(name="contract_duration")  
  14.     private String contract_duration;  
  15.   
  16.     //setters and getters  
  17. }  

2) create configuration file

Open the hibernate.cgf.xml file, and add an entry of mapping resource like this:
  1. <mapping class="com.javatpoint.mypackage.Employee"/>  
  2. <mapping class="com.javatpoint.mypackage.Contract_Employee"/>  
  3. <mapping class="com.javatpoint.mypackage.Regular_Employee"/>  
Now the configuration file will look like this:
File: hibernate.cfg.xml
  1. <?xml version='1.0' encoding='UTF-8'?>  
  2. <!DOCTYPE hibernate-configuration PUBLIC  
  3.           "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  4.           "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">  
  5.   
  6. <!-- Generated by MyEclipse Hibernate Tools.                   -->  
  7. <hibernate-configuration>  
  8.   
  9.     <session-factory>  
  10.         <property name="hbm2ddl.auto">update</property>  
  11.         <property name="dialect">org.hibernate.dialect.Oracle9Dialect</property>  
  12.         <property name="connection.url">jdbc:oracle:thin:@localhost:1521:xe</property>  
  13.         <property name="connection.username">system</property>  
  14.         <property name="connection.password">oracle</property>  
  15. <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>  
  16.           
  17.         <mapping class="com.javatpoint.mypackage.Employee"/>  
  18.         <mapping class="com.javatpoint.mypackage.Contract_Employee"/>  
  19.         <mapping class="com.javatpoint.mypackage.Regular_Employee"/>  
  20.     </session-factory>  
  21.   
  22. </hibernate-configuration>  
The hbm2ddl.auto property is defined for creating automatic table in the database.

3) Create the class that stores the persistent object

In this class, we are simply storing the employee objects in the database.
File: StoreData.java
  1. package com.javatpoint.mypackage;  
  2. import org.hibernate.*;  
  3. import org.hibernate.cfg.*;  
  4.   
  5. public class StoreData {  
  6. public static void main(String[] args) {  
  7.     AnnotationConfiguration cfg=new AnnotationConfiguration();  
  8.     Session session=cfg.configure("hibernate.cfg.xml").buildSessionFactory().openSession();  
  9.       
  10.     Transaction t=session.beginTransaction();  
  11.       
  12.     Employee e1=new Employee();  
  13.     e1.setName("sonoo");  
  14.       
  15.     Regular_Employee e2=new Regular_Employee();  
  16.     e2.setName("Vivek Kumar");  
  17.     e2.setSalary(50000);  
  18.     e2.setBonus(5);  
  19.       
  20.     Contract_Employee e3=new Contract_Employee();  
  21.     e3.setName("Arjun Kumar");  
  22.     e3.setPay_per_hour(1000);  
  23.     e3.setContract_duration("15 hours");  
  24.       
  25.     session.persist(e1);  
  26.     session.persist(e2);  
  27.     session.persist(e3);  
  28.       
  29.     t.commit();  
  30.     session.close();  
  31.     System.out.println("success");  
  32. }