Hibernate联合主键注解方式,即是Hibernate中某一张表出现多个字段联合为唯一主键的情况。这时候就可以使用Hibernate的联合主键来操作。以用户表为例子,userId+userName为唯一主键,因为有时候会出现多个用户的姓名是一样的,如果加上userId就可以控制唯一,判断是否是同一个用户。

注:主键类(UserPK类)是指只有userId和userName的联合字段的类,即是多个字段联合为主键的类==联合主键类。User类是指用户表的实体类。

方式一

主键类(UserPK类):该类实现java.io.Serializable接口,并重写 equals 和 hascode,再将该类注解为@Embeddable。

实体类(User类):该类不包含主键类中的字段,但是需要保存联合主键类的引用,并且生成set和get方法, 并将该引用注解为 @Id 。实体类注解为@Entity和@Table。

实体类:

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.Table;

import java.io.Serializable;

import java.util.Date;

/**

* @author: ZHJ

* @date:Created in 11:15 2020/3/16

* @modify By:

* @description :User的实体类

*/

@Entity

@Table(name = "user")

public class User implements Serializable {

private Integer age;

private String email;

private Date birthday;

@Id

private UserPK userPK;//联合主键类

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

public UserPK getUserPK() {

return userPK;

}

public void setUserPK(UserPK userPK) {

this.userPK = userPK;

}

}

主键类:

import javax.persistence.Embeddable;

import java.io.Serializable;

import java.util.Objects;

/**

* @author: ZHJ

* @date:Created in 11:21 2020/3/16

* @modify By:

* @description :User的联合主键类

*/

@Embeddable

public class UserPK implements Serializable{

private Integer userId;

private String userName;

public Integer getUserId() {

return userId;

}

public void setUserId(Integer userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

//重写hashCode

@Override

public int hashCode() {

return Objects.hash(this.userId,this.userName);

}

//重写equal

@Override

public boolean equals(Object obj) {

if(obj instanceof UserPK){

UserPK key = (UserPK)obj;

if(this.userId.equals(key.getUserId()) && this.userName.equals(key.getUserName())){

return true;

}

}

return false;

}

}

方式二

主键类(UserPK类):该类实现java.io.Serializable接口,并重写 equals 和 hascode,不需要注解@Embeddable。

实体类(User类):该类不包含主键类中的字段,但是需要保存联合主键类的引用,并且生成set和get方法, 并将该引用注解为 @EmbeddedId 。实体类注解为@Entity和@Table。

实体类:

import javax.persistence.EmbeddedId;

import javax.persistence.Entity;

import javax.persistence.Table;

import java.io.Serializable;

import java.util.Date;

/**

* @author: ZHJ

* @date:Created in 11:15 2020/3/16

* @modify By:

* @description :User的实体类

*/

@Entity

@Table(name = "user")

public class User implements Serializable {

private Integer age;

private String email;

private Date birthday;

@EmbeddedId

private UserPK userPK;//联合主键类

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

public UserPK getUserPK() {

return userPK;

}

public void setUserPK(UserPK userPK) {

this.userPK = userPK;

}

}

主键类:

import java.io.Serializable;

import java.util.Objects;

/**

* @author: ZHJ

* @date:Created in 11:21 2020/3/16

* @modify By:

* @description :User的联合主键类

*/

public class UserPK implements Serializable{

private Integer userId;

private String userName;

public Integer getUserId() {

return userId;

}

public void setUserId(Integer userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

//重写hashCode

@Override

public int hashCode() {

return Objects.hash(this.userId,this.userName);

}

//重写equal

@Override

public boolean equals(Object obj) {

if(obj instanceof UserPK){

UserPK key = (UserPK)obj;

if(this.userId.equals(key.getUserId()) && this.userName.equals(key.getUserName())){

return true;

}

}

return false;

}

}

方式三

主键类(UserPK类):该类实现java.io.Serializable接口,并重写 equals 和 hascode,不需要注解@Embeddable。

实体类(User类): 该类包含联合主键类中的字段,将联合主键字段都注解为 @Id,并在该类上方加上注解:@IdClass(联合主键类.class) 。实体类注解为@Entity和@Table。

实体类:

import javax.persistence.*;

import java.io.Serializable;

import java.util.Date;

/**

* @author: ZHJ

* @date:Created in 11:15 2020/3/16

* @modify By:

* @description :User的实体类

*/

@Entity

@Table(name = "user")

@IdClass(UserPK.class)

public class User implements Serializable {

@Id

@Column(name = "user_id", nullable = false, length = 11)

private Integer userId;//联合主键字段

@Id

@Column(name = "user_name", nullable = false, length = 11)

private String userName;//联合主键字段

@Column(name = "age", nullable = true, length = 11)

private Integer age;

@Column(name = "email", nullable = true, length = 240)

private String email;

@Column(name = "birthday", nullable = true, length = 0)

private Date birthday;

public Integer getUserId() {

return userId;

}

public void setUserId(Integer userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

}

主键类:

import java.io.Serializable;

import java.util.Objects;

/**

* @author: ZHJ

* @date:Created in 11:21 2020/3/16

* @modify By:

* @description :User的联合主键类

*/

public class UserPK implements Serializable{

private Integer userId;

private String userName;

public Integer getUserId() {

return userId;

}

public void setUserId(Integer userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

//重写hashCode

@Override

public int hashCode() {

return Objects.hash(this.userId,this.userName);

}

//重写equal

@Override

public boolean equals(Object obj) {

if(obj instanceof UserPK){

UserPK key = (UserPK)obj;

if(this.userId.equals(key.getUserId()) && this.userName.equals(key.getUserName())){

return true;

}

}

return false;

}

}

java 联合主键 注解_Hibernate的联合主键注解方式相关推荐

  1. mysql 联合主键重复数据库_联合主键和复合主键有什么区别

    联合主键和复合主键有什么区别 发布时间:2020-07-11 09:52:20 来源:亿速云 阅读:171 作者:Leah 这期内容当中小编将会给大家带来有关联合主键和复合主键有什么区别,文章内容丰富 ...

  2. sql 复合主键 联合主键_学习SQL:主键

    sql 复合主键 联合主键 If you've already worked with databases, then you could hardly miss the term – Primary ...

  3. mysql复合主键的区别_联合主键和复合主键区别

    什么是数据表的复合主键 所谓的复合主键 就是指你表的主键含有一个以上的字段组成 比如 create table test ( name varchar(19), id number, value va ...

  4. oracle主键约束删除,oracle删除主键查看主键约束及创建联合主键

    oracle删除主键查看主键约束及创建联合主键 1,主键的删除 ALTER TABLE TABLENAME DROP PRIMARY_KEY 执行上面的SQL可以删除主键:如果不成功可以用 ALTER ...

  5. mysql 主键注解_oracle数据库中主键注解

    hibernate5(5)实体映射注解配置[2]主键生成策略 @GeneratedValue基本注解类型 在上一篇文章中,我们讲到了JPA使用@GeneratedValue注解来定义生成策略,而关于注 ...

  6. java 复合主键,Spring Data Jpa 复合主键的实现

    前言 这次大创有个需求,在数据库建表时发现,user表与project表的关系表 user_project的主键为复合主键: CREATE TABLE user_project( user_id IN ...

  7. hibernate 复合主键 根据主键删除_hibernate封装Utils工具类

    一:封装Session对象 1.获取全新的Session的对象 2.获取与线程绑定的的Session的对象 二:什么是持久化类 1.Hlbernate是持久层的ORM映射框架,专注于数据的持久化工作. ...

  8. 【Java】json与java对象转换,获得数据库自增主键,保存返回数据 (个人梳理)

    [Java]json与java对象转换,获得数据库自增主键,保存返回数据 (个人梳理) 模拟请求API 获得json数据,将json转换为java对象,再将java对象转换为list集合,再将list ...

  9. mysql 主键 sql语句_Mysql 增加主键或者修改主键的sql语句操作

    添加表字段 alter table table1 add transactor varchar(10) not null; alter table table1 add id int unsigned ...

最新文章

  1. python版mapreduce题目实现寻找共同好友
  2. 页面置换算法 - FIFO、LFU、LRU
  3. eclipse中的debug按钮组突然找不到了,找回方法
  4. bom .dom_MicroProfile 2.2 BOM导入支持
  5. kafka和storm集成_Storm和Kafka集成的重要生产错误和修复
  6. 在java中实现日期类型和字符串类型的转换大全(Date String Timestamp Datetime)
  7. 才26岁!94年小姐姐,已任985名校副教授!
  8. 福师《计算机应用基础》期末考试a卷数据是,2020年春福师《计算机应用基础》期末考试A卷附答案...
  9. 一些编译php时的configure 参数
  10. php png 透明缩略图,php生成图片缩略图,支持png透明
  11. WPS多版本残留_软件分享猫 wps会员的获取
  12. Sqlserver-循环执行sql语句
  13. l麒麟安装oracle,中标麒麟linux安装Oracle客户端
  14. 双十一海量数据下EagleEye的使命和挑战
  15. 猴年猴赛雷,曙光服务器全面升级E5-v4平台
  16. 《数据结构》:中缀表达式转后缀表达式 后缀表达式的计算
  17. 推荐系统系列——推荐系统简介
  18. 距阵乘以一个未知距阵得单位矩阵 怎么算_一个人可以 DIY 出什么高逼格的东西?...
  19. 全球地名中英文对照表(B)
  20. ubuntu 16.04 和 18.04 替换apt源为阿里源

热门文章

  1. 电子信息专业的学生如何学习嵌入式?
  2. Spock测试套件入门
  3. Brain-X交叉脑科学:新刊正式启动!
  4. dockerfile如何运行镜像内的脚本_如何从看不懂Dockerfile到创建自己的镜像
  5. OPPO Find X兰博基尼版到底有多受欢迎?网友:就是加价也要买
  6. html中报表视图插件,报表控件ActiveReports中全新的WebViewer组件
  7. @升本毕业生,档案转移流程,赶紧了解一下
  8. 兰德系数、调整兰德系数
  9. 让微积分穿梭于工作与学习之间(10):在椭圆弧上做匀速运动,我就无能为力了
  10. Java Swing 图形界面开发(目录)