个性化阅读
专注于IT技术分析

使用注解按层次结构Hibernate表

在上一页中, 我们使用xml文件将继承层次结构映射到一个表。在这里, 我们将使用注释执行此任务。你需要对每个层次结构策略使用@Inheritance(strategy = InheritanceType.SINGLE_TABLE), @ DiscriminatorColumn和@DiscriminatorValue批注来映射表。

如果每个层次结构都有表, 则只需要一个表即可映射继承层次结构。在此, 在表中创建了一个额外的列(也称为鉴别符列)以标识类。

让我们看一下继承层次:

每个类别层次结构使用注解表

此层次结构中有三个类。 Employee是Regular_Employee和Contract_Employee类的超类。

该层次结构的表结构如下所示:
每个类别层次结构使用注解表

使用注释的每个层次结构的Hibernate表示例

你需要按照以下步骤创建简单的示例:

  • 创建持久类
  • 编辑pom.xml文件
  • 创建配置文件
  • 创建类以存储获取数据

1)创建持久类

你需要创建表示继承的持久类。让我们为上述层次结构创建三个类:

文件:Employee.java

package com.srcmini.mypackage;
import javax.persistence.*;

@Entity
@Table(name = "employee101")
@Inheritance(strategy=InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name="type", discriminatorType=DiscriminatorType.STRING)
@DiscriminatorValue(value="employee")

public class Employee {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
    
@Column(name = "id")
private int id;

@Column(name = "name")
private String name;

//setters and getters
}

文件:Regular_Employee.java

package com.srcmini.mypackage;

import javax.persistence.*;

@Entity
@DiscriminatorValue("regularemployee")
public class Regular_Employee extends Employee{
	
@Column(name="salary")	
private float salary;

@Column(name="bonus")	
private int bonus;

//setters and getters
}

文件:Contract_Employee.java

package com.srcmini.mypackage;

import javax.persistence.Column;
import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
@DiscriminatorValue("contractemployee")
public class Contract_Employee extends Employee{
	
	@Column(name="pay_per_hour")
	private float pay_per_hour;
	
	@Column(name="contract_duration")
	private String contract_duration;

	//setters and getters
}

2)在pom.xml文件中添加项目信息和配置。

打开pom.xml文件, 然后单击源。现在, 在<dependencies> …. </ dependencies>标记之间添加以下依赖关系。

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>5.3.1.Final</version>
</dependency>
	
<dependency>
    <groupId>com.oracle</groupId>
    <artifactId>ojdbc14</artifactId>
    <version>10.2.0.4.0</version>
</dependency>

3)在配置文件中添加持久类

打开hibernate.cgf.xml文件, 并添加如下所示的实体类条目:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
		"-//Hibernate/Hibernate Configuration DTD 5.3//EN"
		"http://www.hibernate.org/dtd/hibernate-configuration-5.3.dtd">
<hibernate-configuration>
    <session-factory>
          
    <property name="hbm2ddl.auto">update</property>  
        <property name="dialect">org.hibernate.dialect.Oracle9Dialect</property>  
        <property name="connection.url">jdbc:oracle:thin:@localhost:1521:xe</property>  
        <property name="connection.username">system</property>  
        <property name="connection.password">jtp</property>  
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property> 
     
        <mapping class="com.srcmini.mypackage.Employee"/>
        <mapping class="com.srcmini.mypackage.Regular_Employee"/>
        <mapping class="com.srcmini.mypackage.Contract_Employee"/>
        
    </session-factory>
</hibernate-configuration>

定义了hbm2ddl.auto属性, 用于在数据库中创建自动表。


4)创建存储持久对象的类

在此类中, 我们仅将雇员对象存储在数据库中。

文件:StoreTest.java

package com.srcmini.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 StoreTest {

	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");  	
	}
}

输出:

每个类层次结构的表输出


Hibernate继承映射中的主题

使用xml文件的每个层次结构表

使用注释的每个层次表

使用xml文件的每个具体类的表

使用注释的每混凝土表类

使用XML文件的每个子类表

每个子类的表使用注释

赞(0)
未经允许不得转载:srcmini » 使用注解按层次结构Hibernate表

评论 抢沙发

评论前必须登录!