<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 相似
    有夠爛  回復  更多評論
      
    主站蜘蛛池模板: 日本免费人成黄页在线观看视频| **毛片免费观看久久精品| 免费视频淫片aa毛片| 亚洲AⅤ男人的天堂在线观看| 无码乱肉视频免费大全合集| 亚洲免费电影网站| 亚洲精华国产精华精华液好用| a一级毛片免费高清在线| 亚洲乱码日产精品a级毛片久久| 免费人成再在线观看网站| 亚洲精品久久久www| 国产人成网在线播放VA免费| 亚洲人成网7777777国产| 亚欧免费一级毛片| 亚洲制服丝袜在线播放| 成年私人影院免费视频网站| 亚洲AV无码一区二区三区网址 | 免费99热在线观看| 三级片免费观看久久| 99久久这里只精品国产免费| 亚洲AV综合色区无码一区爱AV| 免费无码毛片一区二区APP| 亚洲午夜成激人情在线影院| 成年美女黄网站18禁免费| 美女视频黄a视频全免费网站一区| 国语成本人片免费av无码| 亚洲av永久无码天堂网| 国产福利电影一区二区三区,亚洲国模精品一区 | 一个人看的www免费高清| 久久亚洲国产精品一区二区| 真人做A免费观看| 亚洲乱码在线播放| 亚洲成av人片一区二区三区| 国产麻豆一精品一AV一免费 | 亚洲第一二三四区| 久久久高清日本道免费观看| 亚洲国模精品一区| 最刺激黄a大片免费网站| 亚洲嫩模在线观看| 在线观看免费为成年视频| 成全高清在线观看免费|