文档章节

复合主键@IdClass

We911
 We911
发布于 2017/02/08 10:17
字数 842
阅读 606
收藏 0

复合主键@idClass

有时一个实体的主键可能同时为多个,例如同样是之前使用的“CustomerEO”实体,需要通过nameemail来查找指定实体,当且仅当nameemail的值完全相同时,才认为是相同的实体对象。要配置这样的复合主键,步骤如以下所示。

1)编写一个复合主键的类CustomerPK,代码如下。

CustomerPK.java

import java.io.Serializable;

 

public class CustomerPK implements Serializable {

 

         public CustomerPK() {

 

         }

 

         public CustomerPK(String name, String email) {

                   this.name = name;

                   this.email = email;

         }

 

         private String email;

 

         public String getEmail() {

                   return email;

         }

 

         public void setEmail(String email) {

                   this.email = email;

         }

 

         private String name;

 

         public String getName() {

                   return name;

         }

 

         public void setName(String name) {

                   this.name = name;

         }

 

         @Override

         public int hashCode() {

                   final int PRIME = 31;

                   int result = 1;

                   result = PRIME * result + ((email == null) ? 0 : email.hashCode());

                   result = PRIME * result + ((name == null) ? 0 : name.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 CustomerPK other = (CustomerPK) obj;

                   if (email == null) {

                            if (other.email != null)

                                     return false;

                   } else if (!email.equals(other.email))

                            return false;

                   if (name == null) {

                            if (other.name != null)

                                     return false;

                   } else if (!name.equals(other.name))

                            return false;

                   return true;

         }

 

}

作为符合主键类,要满足以下几点要求。

l         必须实现Serializable接口。

l         必须有默认的public无参数的构造方法。

l         必须覆盖equalshashCode方法。equals方法用于判断两个对象是否相同,EntityManger通过find方法来查找Entity时,是根据equals的返回值来判断的。本例中,只有对象的nameemail值完全相同时或同一个对象时则返回true,否则返回falsehashCode方法返回当前对象的哈希码,生成的hashCode相同的概率越小越好,算法可以进行优化。

2)通过@IdClass注释在实体中标注复合主键,实体代码如下。

@Entity

@Table(name = "customer")

@IdClass(CustomerPK.class)

public class CustomerEO implements java.io.Serializable {

 

         private Integer id;

 

         public Integer getId() {

                   return this.id;

         }

 

         public void setId(Integer id) {

                   this.id = id;

         }

        

         private String name;

 

@Id

         public String getName() {

                   return this.name;

         }

 

         public void setName(String name) {

                   this.name = name;

         }

        

         private String email;

@Id

         public String getEmail() {

                   return email;

         }

 

         public void setEmail(String email) {

                   this.email = email;

         }

}

标注复合主键时需要注意以下几个问题。

l         @IdClass标注用于标注实体所使用主键规则的类。它的定义如下所示。

@Target({TYPE}) @Retention(RUNTIME)

public @interface IdClass {

Class value();

}

属性Class表示符合主键所使用的类,本例中使用CustomerPK这个复合主键类。

l         在实体中同时标注主键的属性。本例中在emailnamegetter方法前标注@Id,表示符合主键使用这两个属性。

3)这样定义实体的复合主键后,通过以下代码便可以获得指定的实体对象:

    CustomerPK cpk = new CustomerPK("Janet","janetvsfei@yahoo.com.cn");

    CustomerEO instance = entityManager.find(CustomerEO.class, cpk);


本文出自:http://blog.csdn.net/hongchangfirst

hibernate里边的复合主键是需要其他方式来声明的,需要先写一个主键类,把主键字段(如,tour_id和morph_id)封装在一个类里边,并实现hashCode和equals方法,保证hibernate可以确定一个主键,如下:

class Tour_MorphID implements Serializable {

private static final long serialVersionUID = 155771990L;
private Integer Tour_id;
private Integer Morph_id;
@Override
public int hashCode() {
int result = 1;
result = Tour_id.hashCode() + Morph_id.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 Tour_MorphID other = (Tour_MorphID) obj;
if (Tour_id == other.Tour_id && Morph_id == other.Morph_id)
return true;
return false;
}

getter...

setter...

}


然后在需要复合主键类的实体类里边写上@IdClass注解,如下:

@Entity
@IdClass(Tour_MorphID.class)
@Table(name = "Tour_Morph")
public class Tour_Morph implements Serializable {
serialVersionUID ..
@Id
@Column(name = "Tour_id")
private Integer Tour_id;
@Id
@Column(name = "Morph_id")
private Integer Morph_id;

//other fields...
getter...

setter...
}


好,这样就可以了。


本文转载自:http://blog.csdn.net/liduanw/article/details/8847345

We911
粉丝 1
博文 63
码字总数 0
作品 0
深圳
程序员
私信 提问
还是不习惯hibernate等框架

工作需要,现在已转入了java的 ssh 框架开发,上个星期给了我一个BUG,看似很能简单,但着实费了我一天的时间才解决,记录一下。 背景:原来的数据库表结构中,有一个ID字段,毫无疑问,这也...

gx1727
2012/06/04
224
0
springboot jpa 复合主键 联合主键

在开发中,数据库中定义了一个复合主键,这时候在映射不稍微处理下会有一点问题。什么does not define an IdClass错误,乱七八糟的。反正就是有问题。进入正题。 1、首先定义一个复合主键类。...

朝如青丝暮成雪
03/26
129
0
Hibernate 无主键表(复合主键)映射

为什么要有复合主键映射 在现实中我们可能会遇到许多表可能是没有主键的,那么我们对其做映射后使用会是什么样的结果?能正常得到我们想要的吗?结果应该是得不到想要的结果,而得到的可能会...

decodeLife
2012/08/21
3.5K
0
hibernate联合主键 注解方式

方法一:主键类用@Embeddable,pojo类仍然用@Entity但是引用主键类的对象用@Id 主键pojo类: @Embeddablepublic class composeIdPK implements Serializable {private String name;private i......

YOTOO
2014/05/16
12.9K
0
hibernate联合主键 注解方式

上一篇博客写了如何用xml配置联合主键。下面我们看看如何用annotation配置联合主键 方法一:主键类用@Embeddable,pojo类仍然用@Entity但是引用主键类的对象用@Id 主键pojo类: @Embeddablep...

fjsnail
2014/01/05
4.8K
0

没有更多内容

加载失败,请刷新页面

加载更多

华为手机翻译功能怎么使用?这三种方法请务必收藏

华为手机翻译功能怎么使用?在我们的生活中会经常遇到翻译问题,许多外语不好的朋友该怎么办呢?华为手机已经为我们解决了这个问题,今天小编就教大家学会使用华为手机中的三种翻译技巧,需要...

翻译小天才
28分钟前
4
0
企业服务软件开发中需要注意的三个问题

在开发企业服务软件时,我们需要分为:业务需求、用户需求、产品需求,三大需求层次,三个层次互相关联,企业服务软件开发首先要服务业务,需要满足业务的需求,再关注用户体验,也就是用户需...

积木创意科技
31分钟前
4
0
C++容器底层数据结构

内置数组: int arr[10][10];memset(arr,0,10*10*sizeof(int)); //初始化int tmp[10][10];memcpy(arr, tmp, 10 * 10 * sizeof(int));//拷贝 void *memcpy(void *destin, void *source,......

SibylY
31分钟前
3
0
Dubbo-自适应拓展机制

背景 在 Dubbo 中,很多拓展都是通过 SPI 机制进行加载的,比如 Protocol、Cluster、LoadBalance 等,这些都是Dubbo的基础组件。这些基础组件的拓展不是在系统框架启动阶段被加载,而是拓展方...

rock-man
59分钟前
7
0
Kali安装fcitx输入法(五笔)

安装fcitx > sudo apt-get install fcitx-rime fcitx-config-gtk3 重启 > sudo reboot fcitx配置 效果就是这样 配置输入法切换 系统设置...

yeahlife
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部