<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 55  文章 - 187  trackbacks - 0
    <2009年2月>
    25262728293031
    1234567
    891011121314
    15161718192021
    22232425262728
    1234567

    常用鏈接

    留言簿(12)

    隨筆分類

    隨筆檔案

    groovy

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    在設計數據庫表的時候,往往會設計出帶有復合主鍵的表,即表的記錄由多個字段聯合標識,如:


    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;
        }

    }


    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;
        }

    }

    posted on 2009-02-25 14:10 大衛 閱讀(3005) 評論(2)  編輯  收藏 所屬分類: Java

    FeedBack:
    # re: hibernate(jpa)復合主鍵annotation聲明方法 2009-02-26 10:07 Mr.wang
    學習  回復  更多評論
      
    # re: hibernate(jpa)復合主鍵annotation聲明方法 2009-03-03 13:19 相似
    有夠爛  回復  更多評論
      
    主站蜘蛛池模板: 亚洲av无码专区亚洲av不卡| 亚洲AV成人片色在线观看高潮 | 久久亚洲av无码精品浪潮| 在线亚洲v日韩v| 亚洲精品一级无码中文字幕| 国产亚洲蜜芽精品久久| 亚洲AV无码乱码在线观看| 免费无码国产V片在线观看| 中文字幕专区在线亚洲| 四虎国产精品免费永久在线| 久久精品国产亚洲AV网站| 91成人在线免费视频| 亚洲一区二区久久| 日韩成人免费在线| 二级毛片免费观看全程| 久久噜噜噜久久亚洲va久| 18成禁人视频免费网站| 一区二区亚洲精品精华液| 国产免费久久精品| 在线观看黄片免费入口不卡| 亚洲Av永久无码精品三区在线 | 免费精品国产自产拍在线观看| 久久国产成人亚洲精品影院 | 亚洲高清视频在线播放| 国产精品视频免费| 国产成人综合久久精品亚洲| 亚洲欧洲自拍拍偷午夜色无码| 久久久久国色av免费看| 亚洲粉嫩美白在线| 国产亚洲一区二区三区在线不卡 | 亚洲精品国产成人| 日韩在线免费电影| 三级黄色免费观看| 亚洲精品午夜国产va久久| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 丰满亚洲大尺度无码无码专线| 亚洲中文字幕在线观看| 国产精品成人观看视频免费 | 在线播放免费播放av片| 永久免费无码日韩视频| 亚洲图片校园春色|