关闭

jpa复合主键的使用 【转载】

标签: jpa
346人阅读 评论(0) 收藏 举报
分类:

文章出处:jpa复合主键的使用


AirLinePk复合主键类

package com.ljq.entity;

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

/**
 * 使用复合主键要满足的条件
 * 
 * 1、要实现序列化 2、提供默认的构造方法 3、实现hashCope
 * 
 * @author Administrator
 * 
 */

@SuppressWarnings("serial")
@Embeddable  //embeddable: 可嵌入的
public class AirLinePk implements java.io.Serializable {
    @Column(length = 3)
    private String startCity;// 出发城市

    @Column(length = 3)
    private String endCity;// 抵达城市

    public AirLinePk() {
        super();
    }

    public AirLinePk(String startCity, String endCity) {
        super();
        this.startCity = startCity;
        this.endCity = endCity;
    }

    public String getEndCity() {
        return endCity;
    }

    public void setEndCity(String endCity) {
        this.endCity = endCity;
    }

    public String getStartCity() {
        return startCity;
    }

    public void setStartCity(String startCity) {
        this.startCity = startCity;
    }

    @Override
    public int hashCode() {
        final int PRIME = 31;
        int result = 1;
        result = PRIME * result + ((endCity == null) ? 0 : endCity.hashCode());
        result = PRIME * result
                + ((startCity == null) ? 0 : startCity.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        final AirLinePk other = (AirLinePk) obj;
        if (endCity == null) {
            if (other.endCity != null)
                return false;
        } else if (!endCity.equals(other.endCity))
            return false;
        if (startCity == null) {
            if (other.startCity != null)
                return false;
        } else if (!startCity.equals(other.startCity))
            return false;
        return true;
    }

}
AirLine实体类

package com.ljq.entity;


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

@SuppressWarnings("serial")
@Entity
public class AirLine implements java.io.Serializable{
    @EmbeddedId
    private AirLinePk id;
    
    @Column(length=20)
    private String name;

    public AirLine() {
        super();
    }

    public AirLine(String startCity,String endCity, String name) {
        this.id =new AirLinePk(startCity,endCity);
        this.name = name;
    }


    public AirLinePk getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
    
    
    
    
}
PKTest测试类
package com.ljq.test;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

import org.junit.Test;

import com.ljq.entity.AirLine;
import com.ljq.entity.AirLinePk;

public class PKTest {

    @Test
    public void save() {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        
        em.persist(new AirLine("PEK","SHA","北京飞上海"));
        
        
        em.getTransaction().commit();
        em.close();
        factory.close();
        
    }
    
    @Test
    public void find() {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        
        AirLine airLine=em.find(AirLine.class, new AirLinePk("PEK","SHA"));
        System.out.println(airLine.getName());
        
        
        em.getTransaction().commit();
        em.close();
        factory.close();
        
    }
    
    @Test
    public void update() {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        
        AirLine airLine=em.getReference(AirLine.class, new AirLinePk("PEK","SHA"));
        airLine.setName("北京飞上海北京飞上海");
        em.merge(airLine);
        
        
        em.getTransaction().commit();
        em.close();
        factory.close();
        
    }
    
    @SuppressWarnings({ "unused", "unchecked" })
    @Test
    public void list() {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        
        
        List<AirLine> airLines=em.createQuery("select o from AirLine o").getResultList();
        for(AirLine air:airLines){
            System.out.println(air.getName());
        }
        
        em.getTransaction().commit();
        em.close();
        factory.close();
        
    }
    
    @SuppressWarnings({ "unused", "unchecked" })
    @Test
    public void detele() {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("ljq");
        EntityManager em=factory.createEntityManager();
        em.getTransaction().begin();
        
        
        em.remove(em.getReference(AirLine.class, new AirLinePk("PEK","SHA")));
        
        em.getTransaction().commit();
        em.close();
        factory.close();
        
    }

    /**
     * 用来判断映射是否成功
     * 
     */
    @Test
    public void test() {
        Persistence.createEntityManagerFactory("ljq");
    }

}

0
1
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

JPA联合主键并做从表外键

@Embeddable public class BasicOrderPK implements Serializable { ... // 联合主键的两个字段单独生成...
  • lhd85
  • lhd85
  • 2016-06-16 17:38
  • 1629

JPA 菜鸟教程 11 复合主键-2个@Id

复合主键 指多个主键联合形成一个主键组合 需求产生 比如航线一般是由出发地及目的地确定,如果要确定唯一的航线就可以用出发地和目的地一起来表示 ddl语句 CREATE TABLE `t_ai...
  • JE_GE
  • JE_GE
  • 2016-12-17 20:42
  • 4353

在jpa的JpaRepository需要对符合主键@EmbeddedId 中的一个字段进行查询的用法

在jpa的JpaRepository需要对符合主键@EmbeddedId 中的一个字段进行查询的用法: 在JpaRepository Interface中使用findByIdRoleId...
  • remote_roamer
  • remote_roamer
  • 2016-09-30 00:09
  • 2236

JPA复合主键使用

数据库表create table RENT_CERT_VENDOR_TYPE ( CERT_TYPE_ID NUMBER not null, VENDOR_ID ...
  • mypop
  • mypop
  • 2011-01-18 13:51
  • 2873

JPA 菜鸟教程 12 复合主键-2个@Id+@IdClass

复合主键 指多个主键联合形成一个主键组合 需求产生 比如航线一般是由出发地及目的地确定,如果要确定唯一的航线就可以用出发地和目的地一起来表示 ddl语句 同复合主键-2个@Id一样 ...
  • JE_GE
  • JE_GE
  • 2016-12-18 20:02
  • 3424

JPA关联映射 - 复合主键映射

1.persistence.xml JPA规范要求在类路径的META-INF目录下放置persistence.xml <persistence xmlns="http://java.sun.c...
  • jieshaowang1229
  • jieshaowang1229
  • 2014-11-18 22:08
  • 385

JPA 一对一配置,复合主键均为外键

这里有个比较奇怪的表对应关于 其中一张表的主键为一个复合主键 并且这个复合主键中的字段均对应另一张表的主键 配置如下 主体类: @Entity @Table(name="INFO_BRANC...
  • goodsun00
  • goodsun00
  • 2013-03-06 15:30
  • 4395

JPA复合主键另一种实现--联合约束

前言关于复合主键一般是三种方式,但必须创建复合主键类,然后通过注解的方式完成,这三种方式网上很容易找到,这里主要记录自己使用时的一些坑和项目中的特殊需求。 结合JPA使用时,关于Repository类...
  • kane0409
  • kane0409
  • 2017-12-06 13:49
  • 43

JPA 复合主键

定义符合主键的方法:  第一种方法:使用@IdClass  下面是定义一个主键类:  Java代码   public class CustomerPK implements Serializ...
  • u012315127
  • u012315127
  • 2013-12-05 22:40
  • 458

Spring Boot JPA 复合主键只查询部分主键

Spring Data JPA给了我们很强大的功能,我们只需要通过编写一个继承自JpaRepository的接口就能完成数据访问。最近使用过程中,碰到一个问题: 数据库的表中有多个主键,我们和数据...
  • Shallow_Xu
  • Shallow_Xu
  • 2017-07-13 10:09
  • 307
    个人资料
    • 访问:288644次
    • 积分:3838
    • 等级:
    • 排名:第9651名
    • 原创:81篇
    • 转载:177篇
    • 译文:0篇
    • 评论:18条
    最新评论