<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

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    在設(shè)計(jì)數(shù)據(jù)庫表的時候,往往會設(shè)計(jì)出帶有復(fù)合主鍵的表,即表的記錄由多個字段聯(lián)合標(biāo)識,如:


    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
    )
    其中,復(fù)合主鍵為(STAT_DATE,PATH_ID,TYPE)

    針對這種情況,hibernate(jpa) 的 annotation 映射聲明如下:
    1、復(fù)合主鍵類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、實(shí)體類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 大衛(wèi) 閱讀(3005) 評論(2)  編輯  收藏 所屬分類: Java

    FeedBack:
    # re: hibernate(jpa)復(fù)合主鍵annotation聲明方法 2009-02-26 10:07 Mr.wang
    學(xué)習(xí)  回復(fù)  更多評論
      
    # re: hibernate(jpa)復(fù)合主鍵annotation聲明方法 2009-03-03 13:19 相似
    有夠爛  回復(fù)  更多評論
      
    主站蜘蛛池模板: 国产亚洲sss在线播放| 亚洲性线免费观看视频成熟| 亚洲香蕉在线观看| 亚洲人成人一区二区三区| 日本免费一本天堂在线| 又粗又大又黑又长的免费视频| 巨胸狂喷奶水视频www网站免费| 亚洲色一区二区三区四区| 91亚洲国产成人精品下载| 精品国产亚洲男女在线线电影| 女人毛片a级大学毛片免费| 久久w5ww成w人免费| 巨胸狂喷奶水视频www网站免费| 最新亚洲人成无码网www电影| 亚洲免费观看网站| 久久亚洲日韩看片无码| 亚洲AV无码一区二区三区系列 | 亚洲图片激情小说| 亚洲国产人成在线观看69网站| 亚洲无线码一区二区三区| 亚洲国产日韩成人综合天堂| 哒哒哒免费视频观看在线www| 国内永久免费crm系统z在线 | 国产成人亚洲精品91专区手机| 黄色毛片免费网站| 国产亚洲精品福利在线无卡一| 国产一级淫片a视频免费观看| 香蕉高清免费永久在线视频| 18禁止观看免费私人影院| 人妻无码久久一区二区三区免费 | 中文字幕久无码免费久久| 羞羞视频免费网站日本| 午夜免费国产体验区免费的 | 日韩视频在线免费| 欧美大尺寸SUV免费| 国产精品美女午夜爽爽爽免费| AV大片在线无码永久免费| 曰批全过程免费视频网址| 6080午夜一级毛片免费看| 最近中文字幕电影大全免费版| 51精品视频免费国产专区|