快速业务通道

hibernate(jpa)复合主键annotation声明方法 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-16

hibernate(jpa)复合主键annotation声明方法

时间:2011-06-16 BlogJava 大卫

在设计数据库表的时候,往往会设计出带有复合主键的表,即表的记录由多 个字段联合标识,如:

CREATE TABLE TB_HOUR_DATA (   STAT_DATE  DATE                   NOT NULL,   PATH_ID    NUMBER(20)             NOT NULL,   VALUE      VARCHAR2(512 BYTE),   TYPE       NUMBER(1)              NOT NULL )

其中,复合主键为(STAT_DATE,PATH_ID,TYPE)

针对这种情况,hibernate(jpa) 的 annotation 映射声明如下:

1、复合主键类HourDataPK

package net.kong.wolf.stat.db.entity; import java.io.Serializable; import java.util.Date; import javax.persistence.Column; import javax.persistence.Embeddable; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.Temporal; import javax.persistence.TemporalType; @Embeddable public class HourDataPK implements Serializable {     /** *//**      *      */     private static final long serialVersionUID = 1L;     @ManyToOne     @JoinColumn(name = "path_id", nullable = false)     private Path path;     @Column(name = "stat_date")     @Temporal(TemporalType.DATE)     private Date statDate;     private int type;     public Path getPath() {         return path;     }     public void setPath(Path path) {         this.path = path;     }     public Date getStatDate() {         return statDate;     }     public void setStatDate(Date statDate) {         this.statDate = statDate;     }     public int getType() {         return type;     }     public void setType(int type) {         this.type = type;     } }

hibernate(jpa)复合主键annotation声明方法(2)

时间:2011-06-16 BlogJava 大卫

2、实体类HourData:

package net.kong.wolf.stat.db.entity; import java.io.Serializable; import javax.persistence.EmbeddedId; import javax.persistence.Entity; import javax.persistence.Table; import net.kong.wolf.stat.core.Text; @Entity @Table(name = "TB_HOUR_DATA") public class HourData implements Serializable {     /** *//**      *      */     private static final long serialVersionUID = 1L;     @EmbeddedId     private HourDataPK pk;     private String value;     public String getValue() {         return value;     }     public void setValue(String value) {         this.value = value;     }     public int[] getHours() {         return parseValue(value);     }     private int[] parseValue(String value) {         int[] result = new int[24];         for (int i = 0; i < 24; i++) {             result[i] = -1;         }         if (value == null) {             return result;         }         String[] hs = Text.splitCSV(value);         int len = Math.min(24, hs.length);         for (int i = 0; i < len; i++) {             result[i] = Text.parseInt(hs[i], -1);         }         return result;     }     public void setHours(int[] hours) {         int[] tHours = parseValue(value);         StringBuilder sb = new StringBuilder();         int len = Math.min(24, hours.length);         for (int i = 0; i < len; i++) {             sb.append(hours[i] < 0 ? tHours[i] : hours[i]).append('','');         }         sb.deleteCharAt(sb.length() - 1);         this.value = sb.toString();     }     public HourDataPK getPk() {         return pk;     }     public void setPk(HourDataPK pk) {         this.pk = pk;     } }

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号