java hibernate使用注解來定義聯(lián)合主鍵
java hibernate使用注解來定義聯(lián)合主鍵
下面使用hibernate的API中說明的三種方式來定義主鍵,主要使用Annotation來定義hibernate中的聯(lián)合主鍵
下面取至hibernate的API文檔:
定義組合主鍵的幾種語法:
1、將組件類注解為@Embeddable,并將組件的屬性注解為@Id
2、將組件的屬性注解為@EmbeddedId
3、將類注解為@IdClass,并將該實(shí)體中所有屬于主鍵的屬性都注解為@Id
下面就分別使用這三種方式來定義聯(lián)合主鍵。
建表的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、主鍵類必須要實(shí)現(xiàn)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,并將該實(shí)體中所有屬于主鍵的屬性都注解為@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;
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- JAVA中通過Hibernate-Validation進(jìn)行參數(shù)驗(yàn)證
- 詳解JAVAEE——SSH三大框架整合(spring+struts2+hibernate)
- Java框架篇:Spring+SpringMVC+hibernate整合開發(fā)
- Java的Hibernate框架中復(fù)合主鍵映射的創(chuàng)建和使用教程
- Java的Hibernate框架結(jié)合MySQL的入門學(xué)習(xí)教程
- 從最基本的Java工程搭建SpringMVC+SpringDataJPA+Hibernate
- 在Java的Hibernate框架中使用SQL語句的簡單介紹
- Java web Hibernate如何與數(shù)據(jù)庫鏈接
相關(guān)文章
java使用compareTo實(shí)現(xiàn)一個類的對象之間比較大小操作
這篇文章主要介紹了java使用compareTo實(shí)現(xiàn)一個類的對象之間比較大小操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
java實(shí)現(xiàn)區(qū)域內(nèi)屏幕截圖示例
這篇文章主要介紹了java截圖示例,需要的朋友可以參考下2014-04-04
SpringBoot全局異常處理機(jī)制和配置攔截器方式
這篇文章主要介紹了SpringBoot全局異常處理機(jī)制和配置攔截器方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
java中構(gòu)造方法及this關(guān)鍵字的用法實(shí)例詳解(超詳細(xì))
大家都知道,java作為一門內(nèi)容豐富的編程語言,其中涉及的范圍是十分廣闊的,下面這篇文章主要給大家介紹了關(guān)于java中構(gòu)造方法及this關(guān)鍵字用法的相關(guān)資料,需要的朋友可以參考下2022-04-04
Spring處理@Async導(dǎo)致的循環(huán)依賴失敗問題的方案詳解
這篇文章主要為大家詳細(xì)介紹了SpringBoot中的@Async導(dǎo)致循環(huán)依賴失敗的原因及其解決方案,文中的示例代碼講解詳細(xì),感興趣的可以學(xué)習(xí)一下2022-07-07

