<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 大衛 閱讀(3015) 評論(2)  編輯  收藏 所屬分類: Java

    FeedBack:
    # re: hibernate(jpa)復合主鍵annotation聲明方法 2009-02-26 10:07 Mr.wang
    學習  回復  更多評論
      
    # re: hibernate(jpa)復合主鍵annotation聲明方法 2009-03-03 13:19 相似
    有夠爛  回復  更多評論
      
    主站蜘蛛池模板: 好男人视频在线观看免费看片| 免费国产不卡午夜福在线| 亚洲日本天堂在线| 国内精品99亚洲免费高清| 91精品国产免费入口| 国产精品亚洲一区二区三区在线观看| 亚洲欧洲∨国产一区二区三区| 无码国产精品一区二区免费式直播| 免费看一级一级人妻片| 久久久亚洲欧洲日产国码是AV| 日本19禁啪啪无遮挡免费动图| 最近免费中文字幕中文高清| 亚洲精品GV天堂无码男同| 国产亚洲一区二区手机在线观看| 成熟女人特级毛片www免费| 免费成人在线电影| 美女被免费网站视频在线| 亚洲精品福利在线观看| 亚洲女同成人AⅤ人片在线观看| 无码国产精品一区二区免费式影视 | 久久午夜无码免费| 精品亚洲国产成人av| 亚洲毛片免费视频| 亚洲熟妇无码另类久久久| 精品免费久久久久久成人影院| 鲁大师在线影院免费观看| EEUSS影院WWW在线观看免费| 亚洲欧美国产国产一区二区三区| 亚洲AV乱码一区二区三区林ゆな| 亚洲成av人在片观看| 麻豆国产人免费人成免费视频| 91在线手机精品免费观看| 中国好声音第二季免费播放| 疯狂做受xxxx高潮视频免费| 学生妹亚洲一区二区| 亚洲第一页在线观看| 亚洲国产成人精品不卡青青草原| 亚洲精品tv久久久久久久久久| 日本牲交大片免费观看| 成年女人毛片免费播放视频m| 午夜免费1000部|