JPA 嵌入式ID示例

2018-02-23 15:56 更新

JPA教程 - JPA 嵌入式ID示例


以下代码显示了如何将类用作嵌入式ID。

首先它创建一个Embeddable实体。

@Embeddable
public class ProfessorId implements Serializable{
  private String country;

  @Column(name = "EMP_ID")
  private int id;

它用 @EmbeddedId 注释标记 ProfessorId

@Entity
public class Professor {
  @EmbeddedId
  private ProfessorId id;

例子

以下代码来自Professor.java。

package cn.w3cschool.common;

import javax.persistence.EmbeddedId;
import javax.persistence.Entity;

@Entity
public class Professor {
  @EmbeddedId
  private ProfessorId id;

  private String name;

  private long salary;

  public Professor() {
  }

  public Professor(String country, int id) {
    this.id = new ProfessorId(country, id);
  }

  public int getId() {
    return id.getId();
  }

  public String getCountry() {
    return id.getCountry();
  }

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

  public long getSalary() {
    return salary;
  }

  public void setSalary(long salary) {
    this.salary = salary;
  }

  public String toString() {
    return "Professor id: " + getId() + " name: " + getName() + " country: " + getCountry();
  }
}

以下代码来自ProfessorId.java。

package cn.w3cschool.common;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Embeddable;

@Embeddable
public class ProfessorId implements Serializable{
  private String country;

  @Column(name = "EMP_ID")
  private int id;

  public ProfessorId() {
  }

  public ProfessorId(String country, int id) {
    this.country = country;
    this.id = id;
  }

  public String getCountry() {
    return country;
  }

  public int getId() {
    return id;
  }

  public boolean equals(Object o) {
    return ((o instanceof ProfessorId) && country.equals(((ProfessorId) o).getCountry()) && id == ((ProfessorId) o)
        .getId());

  }

  public int hashCode() {
    return country.hashCode() + id;
  }
}

下面的代码来自PersonDaoImpl.java。

package cn.w3cschool.common;


import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

import org.springframework.transaction.annotation.Transactional;

@Transactional
public class PersonDaoImpl {
  public void test(){
    
    Professor emp = new Professor("US", 1);
    emp.setName("Tom");
    emp.setSalary(1);
    em.persist(emp);
  }
  @PersistenceContext
  private EntityManager em;
}
下载 EmbeddedID.zip

以下是数据库转储。

Table Name: PROFESSOR
 Row:
    Column Name: COUNTRY,
    Column Type: VARCHAR:
    Column Value: US

    Column Name: EMP_ID,
    Column Type: INTEGER:
    Column Value: 1

    Column Name: NAME,
    Column Type: VARCHAR:
    Column Value: Tom

    Column Name: SALARY,
    Column Type: BIGINT:
    Column Value: 1


以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号