java  hibernate使用注解来定义联合主键

所属分类: 软件编程 / java 阅读数: 29
收藏 0 赞 0 分享

java  hibernate使用注解来定义联合主键

下面使用hibernate的API中说明的三种方式来定义主键,主要使用Annotation来定义hibernate中的联合主键

下面取至hibernate的API文档:

定义组合主键的几种语法:

1、将组件类注解为@Embeddable,并将组件的属性注解为@Id
2、将组件的属性注解为@EmbeddedId
3、将类注解为@IdClass,并将该实体中所有属于主键的属性都注解为@Id

下面就分别使用这三种方式来定义联合主键。

建表的SQL语句:

CREATE TABLE `syslogs` ( 
 `id` varchar(50) NOT NULL, 
 `yhid` varchar(50) NOT NULL, 
 `modelname` varchar(100) DEFAULT NULL, 
 `content` varchar(500) DEFAULT NULL, 
 `inserttime` varchar(20) DEFAULT NULL, 
 `remark` varchar(50) DEFAULT NULL, 
 PRIMARY KEY (`id`,`yhid`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf-8; 

一、将组件类注解为@Embeddable

/** 
 * SysLogsDtoId代表主键类 
 */ 
package com.hibernate.dto; 
 
import javax.persistence.Embeddable; 
/** 
 * 1、主键类必须要实现java.io.Serializable接口 
 * 2、主键类必须要重写equals和hashCode方法 
 * @author ibm 
 */ 
@Embeddable 
public class SysLogsDtoId implements java.io.Serializable { 
 
  private static final long serialVersionUID = 1L; 
  private String id; 
  private String yhid; 
 
  public SysLogsDtoId() { 
  } 
 
  public SysLogsDtoId(String id, String yhid) { 
    this.id = id; 
    this.yhid = yhid; 
  } 
 
  public String getId() { 
    return this.id; 
  } 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  public String getYhid() { 
    return this.yhid; 
  } 
 
  public void setYhid(String yhid) { 
    this.yhid = yhid; 
  } 
 
  public boolean equals(Object other) { 
    if ((this == other)) 
      return true; 
    if ((other == null)) 
      return false; 
    if (!(other instanceof SysLogsDtoId)) 
      return false; 
    SysLogsDtoId castOther = (SysLogsDtoId) other; 
 
    return ((this.getId() == castOther.getId()) || (this.getId() != null && castOther.getId() != null && this.getId().equals(castOther.getId()))) 
        && ((this.getYhid() == castOther.getYhid()) || (this.getYhid() != null && castOther.getYhid() != null && this.getYhid().equals( 
            castOther.getYhid()))); 
  } 
 
  public int hashCode() { 
    int result = 17; 
 
    result = 37 * result + (getId() == null ? 0 : this.getId().hashCode()); 
    result = 37 * result + (getYhid() == null ? 0 : this.getYhid().hashCode()); 
    return result; 
  } 
 
} 

/** 
 * SysLogsDto为表对象映射类,其中主键为主键类SysLogsDtoId 
 */ 
package com.hibernate.dto; 
 
import javax.persistence.Column; 
import javax.persistence.Entity; 
import javax.persistence.Id; 
import javax.persistence.Table; 
 
@Entity 
@Table(name = "syslogs") 
public class SysLogsDto implements java.io.Serializable { 
  private static final long serialVersionUID = 1L; 
  private SysLogsDtoId id; 
  private String modelname; 
  private String content; 
  private String inserttime; 
  private String remark; 
 
  public SysLogsDto() { 
  } 
 
  public SysLogsDto(SysLogsDtoId id) { 
    this.id = id; 
  } 
 
  public SysLogsDto(SysLogsDtoId id, String modelname, String content, String inserttime, String remark) { 
    this.id = id; 
    this.modelname = modelname; 
    this.content = content; 
    this.inserttime = inserttime; 
    this.remark = remark; 
  } 
 
  @Id 
  public SysLogsDtoId getId() { 
    return this.id; 
  } 
 
  public void setId(SysLogsDtoId id) { 
    this.id = id; 
  } 
 
  @Column(name = "modelname", length = 100) 
  public String getModelname() { 
    return this.modelname; 
  } 
 
  public void setModelname(String modelname) { 
    this.modelname = modelname; 
  } 
 
  @Column(name = "content", length = 500) 
  public String getContent() { 
    return this.content; 
  } 
 
  public void setContent(String content) { 
    this.content = content; 
  } 
 
  @Column(name = "inserttime", length = 20) 
  public String getInserttime() { 
    return this.inserttime; 
  } 
 
  public void setInserttime(String inserttime) { 
    this.inserttime = inserttime; 
  } 
 
  @Column(name = "remark", length = 50) 
  public String getRemark() { 
    return this.remark; 
  } 
 
  public void setRemark(String remark) { 
    this.remark = remark; 
  } 
 
} 

二、将组件的属性注解为@EmbeddedId

这种情况最简单,主键类只用定义主键字段,不需要写任何注解。然后在对象类中在主键类的get方法上加上@EmbeddedId注解。

/** 
 * SysLogsDtoId代表主键类 
 */ 
package com.hibernate.dto; 
 
public class SysLogsDtoId implements java.io.Serializable { 
 
  private static final long serialVersionUID = 1L; 
  private String id; 
  private String yhid; 
 
  public SysLogsDtoId() { 
  } 
 
  public SysLogsDtoId(String id, String yhid) { 
    this.id = id; 
    this.yhid = yhid; 
  } 
 
  public String getId() { 
    return this.id; 
  } 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  public String getYhid() { 
    return this.yhid; 
  } 
 
  public void setYhid(String yhid) { 
    this.yhid = yhid; 
  } 
 
  public boolean equals(Object other) { 
    if ((this == other)) 
      return true; 
    if ((other == null)) 
      return false; 
    if (!(other instanceof SysLogsDtoId)) 
      return false; 
    SysLogsDtoId castOther = (SysLogsDtoId) other; 
 
    return ((this.getId() == castOther.getId()) || (this.getId() != null && castOther.getId() != null && this.getId().equals(castOther.getId()))) 
        && ((this.getYhid() == castOther.getYhid()) || (this.getYhid() != null && castOther.getYhid() != null && this.getYhid().equals( 
            castOther.getYhid()))); 
  } 
 
  public int hashCode() { 
    int result = 17; 
 
    result = 37 * result + (getId() == null ? 0 : this.getId().hashCode()); 
    result = 37 * result + (getYhid() == null ? 0 : this.getYhid().hashCode()); 
    return result; 
  } 
 
} 



/** 
 * SysLogsDto为表对象映射类,其中主键为主键类SysLogsDtoId 
 */ 
package com.hibernate.dto; 
 
import javax.persistence.Column; 
import javax.persistence.EmbeddedId; 
import javax.persistence.Entity; 
import javax.persistence.Table; 
 
@Entity 
@Table(name = "syslogs") 
public class SysLogsDto implements java.io.Serializable { 
  private static final long serialVersionUID = 1L; 
  private SysLogsDtoId id; 
  private String modelname; 
  private String content; 
  private String inserttime; 
  private String remark; 
 
  public SysLogsDto() { 
  } 
 
  public SysLogsDto(SysLogsDtoId id) { 
    this.id = id; 
  } 
 
  public SysLogsDto(SysLogsDtoId id, String modelname, String content, String inserttime, String remark) { 
    this.id = id; 
    this.modelname = modelname; 
    this.content = content; 
    this.inserttime = inserttime; 
    this.remark = remark; 
  } 
 
  @EmbeddedId 
  public SysLogsDtoId getId() { 
    return this.id; 
  } 
 
  public void setId(SysLogsDtoId id) { 
    this.id = id; 
  } 
 
  @Column(name = "modelname", length = 100) 
  public String getModelname() { 
    return this.modelname; 
  } 
 
  public void setModelname(String modelname) { 
    this.modelname = modelname; 
  } 
 
  @Column(name = "content", length = 500) 
  public String getContent() { 
    return this.content; 
  } 
 
  public void setContent(String content) { 
    this.content = content; 
  } 
 
  @Column(name = "inserttime", length = 20) 
  public String getInserttime() { 
    return this.inserttime; 
  } 
 
  public void setInserttime(String inserttime) { 
    this.inserttime = inserttime; 
  } 
 
  @Column(name = "remark", length = 50) 
  public String getRemark() { 
    return this.remark; 
  } 
 
  public void setRemark(String remark) { 
    this.remark = remark; 
  } 
 
} 

三、将类注解为@IdClass,并将该实体中所有属于主键的属性都注解为@Id

/** 
 * SysLogsDtoId代表主键类 
 */ 
package com.hibernate.dto; 
 
public class SysLogsDtoId implements java.io.Serializable { 
 
  private static final long serialVersionUID = 1L; 
  private String id; 
  private String yhid; 
 
  public SysLogsDtoId() { 
  } 
 
  public SysLogsDtoId(String id, String yhid) { 
    this.id = id; 
    this.yhid = yhid; 
  } 
 
  public String getId() { 
    return this.id; 
  } 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  public String getYhid() { 
    return this.yhid; 
  } 
 
  public void setYhid(String yhid) { 
    this.yhid = yhid; 
  } 
 
  public boolean equals(Object other) { 
    if ((this == other)) 
      return true; 
    if ((other == null)) 
      return false; 
    if (!(other instanceof SysLogsDtoId)) 
      return false; 
    SysLogsDtoId castOther = (SysLogsDtoId) other; 
 
    return ((this.getId() == castOther.getId()) || (this.getId() != null && castOther.getId() != null && this.getId().equals(castOther.getId()))) 
        && ((this.getYhid() == castOther.getYhid()) || (this.getYhid() != null && castOther.getYhid() != null && this.getYhid().equals( 
            castOther.getYhid()))); 
  } 
 
  public int hashCode() { 
    int result = 17; 
 
    result = 37 * result + (getId() == null ? 0 : this.getId().hashCode()); 
    result = 37 * result + (getYhid() == null ? 0 : this.getYhid().hashCode()); 
    return result; 
  } 
 
} 

/** 
 * SysLogsDto为表对象映射类,其中主键为主键类SysLogsDtoId 
 */ 
package com.hibernate.dto; 
 
import javax.persistence.Column; 
import javax.persistence.Entity; 
import javax.persistence.Id; 
import javax.persistence.IdClass; 
import javax.persistence.Table; 
 
@Entity 
@Table(name = "syslogs") 
@IdClass(value=SysLogsDtoId.class) 
public class SysLogsDto implements java.io.Serializable { 
  private static final long serialVersionUID = 1L; 
  private String id; 
  private String yhid; 
  private String modelname; 
  private String content; 
  private String inserttime; 
  private String remark; 
 
  public SysLogsDto() { 
  } 
 
  @Id 
  public String getId() { 
    return id; 
  } 
 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  @Id 
  public String getYhid() { 
    return yhid; 
  } 
 
 
  public void setYhid(String yhid) { 
    this.yhid = yhid; 
  } 
 
 
  @Column(name = "modelname", length = 100) 
  public String getModelname() { 
    return this.modelname; 
  } 
 
  public void setModelname(String modelname) { 
    this.modelname = modelname; 
  } 
 
  @Column(name = "content", length = 500) 
  public String getContent() { 
    return this.content; 
  } 
 
  public void setContent(String content) { 
    this.content = content; 
  } 
 
  @Column(name = "inserttime", length = 20) 
  public String getInserttime() { 
    return this.inserttime; 
  } 
 
  public void setInserttime(String inserttime) { 
    this.inserttime = inserttime; 
  } 
 
  @Column(name = "remark", length = 50) 
  public String getRemark() { 
    return this.remark; 
  } 
 
  public void setRemark(String remark) { 
    this.remark = remark; 
  } 
 
} 

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

更多精彩内容其他人还在看

SpringBoot环境搭建及第一个程序运行(小白教程)

这篇文章主要介绍了SpringBoot环境搭建及第一个程序运行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

过滤器 和 拦截器的 6个区别(别再傻傻分不清了)

这篇文章主要介绍了过滤器 和 拦截器的 6个区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

SpringBoot整合SpringTask实现定时任务的流程

这篇文章主要介绍了SpringBoot整合SpringTask实现定时任务的流程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

vscode快速引入第三方jar包发QQ邮件

这篇文章主要介绍了vscode快速引入第三方jar包发QQ邮件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Java Enum和String及int的相互转化示例

这篇文章主要介绍了Java Enum和String及int的相互转化示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Spring boot如何快速的配置多个Redis数据源

这篇文章主要介绍了Spring boot如何快速的配置多个Redis数据源,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

JAVA 对接腾讯云直播的实现

这篇文章主要介绍了JAVA 对接腾讯云直播的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

JavaSE static final及abstract修饰符实例解析

这篇文章主要介绍了JavaSE static final及abstract修饰符实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

SpringBoot定时任务参数运行代码实例解析

这篇文章主要介绍了SpringBoot定时任务运行代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Spring Boot调用 Shell 脚本实现看门狗功能

这篇文章主要介绍了Spring Boot调用 Shell 脚本实现看门狗功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多