JPA联合主键的使用

对于绝大多数情况一个表只会有一个字段是主键,但是比较特殊的情况下可能会有多个字段一起构成主键,这样的主键就是联合主键了。下面用一个小例子来说明这个情况,我们知道飞行用的航线一般有起点和终点构成,也就是说可以根据起点和终点确定航线,这种情况联合主键就能发挥它的作用了。针对这种情况我们需要把起点和终点封装成一个对象之后作为联合主键使用。

1  联合主键的java类

package org.lxh.info;

import java.io.Serializable;

import javax.persistence.Embeddable;

@Embeddable
public class Destination implements Serializable{
	private String start;
	private String end;

	public String getStart() {
		return start;
	}

	public void setStart(String start) {
		this.start = start;
	}

	public String getEnd() {
		return end;
	}

	public void setEnd(String end) {
		this.end = end;
	}
}

作为联合主键的这个类必须实现Serializable接口并且类的最上面还应该有@Embeddable注解

2 用于持久化的实体类

package org.lxh.info;

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

@Entity
public class AirPlanMessage {
	private Destination id;
	private String lineName;
	private String companyName;
        @EmbeddedId
	public Destination getId() {
		return id;
	}

	public void setId(Destination id) {
		this.id = id;
	}

	public String getLineName() {
		return lineName;
	}

	public void setLineName(String lineName) {
		this.lineName = lineName;
	}

	public String getCompanyName() {
		return companyName;
	}

	public void setCompanyName(String companyName) {
		this.companyName = companyName;
	}
}

和之前不同的是这个实体类中主键就不使用@Id了而是使用@EmbeddedId,加了这个注解就说明这里的主键是联合主键

3  数据的保存操作

package org.lxh.test;

import static org.junit.Assert.*;
import java.util.*;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import org.lxh.info.AirPlanMessage;
import org.lxh.info.Destination;
import org.lxh.info.Sex;
import org.lxh.info.Student;
import org.lxh.info.Teacher;
import org.lxh.info.User;
import org.lxh.info.UserDetails;
import org.lxh.util.JpaUtil;

public class Test {

	@org.junit.Test
	public void testUnionPK() {
		EntityManager em=null;
		EntityTransaction tx=null;
		try{
			em=JpaUtil.getEntityManager();
			tx=em.getTransaction();
			tx.begin();

			Destination des=new Destination();
			des.setStart("昆明");
			des.setEnd("上海");

			AirPlanMessage air=new AirPlanMessage();
			air.setId(des);
			air.setLineName("昆明到上海");
			air.setCompanyName("东方航空");

			em.persist(air);

			tx.commit();
		}catch(Exception e){
			e.printStackTrace();
		}finally{
			if(em!=null){
				em.close();
			}
		}

	}
}

最后来看下生成的这个表的结构

时间: 2024-10-12 02:31:59

JPA联合主键的使用的相关文章

JPA联合主键@EmbeddedId使用详解附查询例子

花了2个小时的时间解决这个问题,网上资料太少,记录下 详情看源文件TBicPrmCompute,TBicPrmComputePK package com.isoftstone.core.domain; import java.io.Serializable; import javax.persistence.*; /** * The persistent class for the T_BIC_PRM_COMPUTE database table. * */ @Entity @NamedQuer

JPA学习---第十二节:JPA中的联合主键

1.定义实体类,代码如下: (1).将联合主键放到一个类中,代码如下: package learn.jpa.entity; import java.io.Serializable; import javax.persistence.Column; import javax.persistence.Embeddable; /** * * 1.必须要有无擦得构造函数 * 2.必须要实现序列接口 * 3.必须重写 equals() 和 hashCode() 方法 * @Embeddable 告诉 jp

JPA注解实现联合主键

当表中一个主键不能唯一标识一条记录的时候,就需要使用联合主键了,下面是使用JPA注解实现联合主键的代码 1 首先需要建立一个复合主键类,用来存放需要生产联合主键的属性,该类需要实现序列化. package com.ericsson.adp.entity.cons; import java.io.Serializable; public class ConsumerGroupMapPK implements Serializable{ private String msisdn;//电话号码 pr

Hibernate(5)—— 联合主键 、一对一关联关系映射(xml和注解) 和 领域驱动设计

俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/Annotation) 联合主键 一对一单向外键联合主键(Xml/Annotation) 一对一组件关联(XML/Annotation) 理解组件 领域驱动设计——自动生成数据库脚本 一对一关系的小结 一些出错问题的总结 自动生成数据库脚本 一般在项目开发过程中,我们的习惯是先建好数据库和表,然后在进

hibernate里联合主键composite-id映射,查询单个主键的问题(转)

今天项目中遇到这个问题,搞了大半天,我郁闷...hibernate里联合主键配置(多个字段一起作为主键) <class name="com.cskj.hibernate.map.BbWjjc" table="bb_wjjc" schema="dbo" catalog="wjgl">        <composite-id name="id" class="com.cskj.hi

hibernate学习:联合主键2

一:运行上一篇文章的程序会发现,后台输出两个warn 17:22:14,232  WARN RootClass:233 - composite-id class does not override equals(): com.hibernate.model.TeacherPK 17:22:14,234  WARN RootClass:238 - composite-id class does not override hashCode(): com.hibernate.model.Teacher

SQL Server中的联合主键、聚集索引、非聚集索引

我们都知道在一个表中当需要2列以上才能确定记录的唯一性的时候,就需要用到联合主键,当建立联合主键以后,在查询数据的时候性能就会有很大的提升,不过并不是对联合主键的任何列单独查询的时候性能都会提升,但我们依然可以通过对联合主键中的首列除外的其他列建立非聚集索引来提高性能.本文将对联合主键.聚集索引.非聚集索引对查询性能的影响举例说明.步骤一,建立一个测试表,并且插入350万条以上的数据. /*创建测试数据表*/create table MyTestTable(id varchar(10)not n

hibernate里联合主键composite-id映射,查询单个主键的问题

今天项目中遇到这个问题,搞了大半天,现在记录下来hibernate里联合主键配置(多个字段一起作为主键) <class name="com.cskj.hibernate.map.BbWjjc" table="bb_wjjc" schema="dbo" catalog="wjgl"> <composite-id name="id" class="com.cskj.hibernate

联合主键有什么用?

联合主键就是用2个或2个以上的字段组成主键.用这个主键包含的字段作为主键,这个组合在数据表中是唯一,且加了主键索引.可以这么理解,比如,你的订单表里有很多字段,一般情况只要有个订单号bill_no做主键就可以了,但是,现在要求可能会有补充订单,使用相同的订单号,那么这时单独使用订单号就不可以了,因为会有重复.那么你可以再使用个订单序列号bill_seq来作为区别.把bill_no和bill_seq设成联合主键.即使bill_no相同,bill_seq不同也是可以的. alter table 表