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

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

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

    posts - 66,  comments - 11,  trackbacks - 0
        我們的目標是為數據邏輯層及業務邏輯層提供更加易于操作的對象,根據這里的情況,將email字段映射為一個List集合

    類型是個不錯的選擇,如何將一個字段映射為List類型,Hibernate并沒有提供原生支持,我們必須實現自己的UserType.
      
    package com.wyq.hibernate;

    public interface UserType {
        
    /**
         * 返回UserType所映射字段的SQL類型(java.sql.Types)
         * 返回類型為int[],其中包含了映射各字段的SQL類型代碼
         * (UserType可以映射到一個或者多個字段)
         * 
    @see java.sql.Types
         * 
    @return int[] the typecodes
         
    */
        
    public int[] sqlTypes();
        
    /**
         * UserType.nullSafeGet()所返回的自定義數據類型
         * 
    @return Class
         
    */
        
    public Class returnedClass();
        
    /**
         * 自定義數據類型的對比方法
         * 此方法將用作臟數據檢查,參數x,y分別為數據的2個副本
         * 如果equals方法返回false,則Hibernate將認為數據發生變化,并將變化更新到庫表中
         
    */
        
    public boolean equals(Object x,Object y)throws HiberanteException;
        
    /**
         * 從JDBC ResultSet讀出數據,將其轉換為自定義類型后返回
         * (此方法要求對可能出現的null值進行處理)
         * names中包含了當前自定義類型的映射字段名稱。
         
    */
        
    public Object nullSafeGet(ResultSet rs,String[] names,Object owner)throws HibernateException,SQLException;
        
    /**
         * 本方法將在Hibernate進行數據保存時被調用
         * 我們可以通過PreparedStatement將自定義數據寫入對應的庫表字段
         
    */
        
    public void nullSafeSet(PreparedStatement st,Object value,int index)throws HibernateException,SQLException;
        
    /**
         * 提供自定義類型的完全復制方法
         * 本方法將用作構造返回對象
         * 當nullSafeGet方法調用之后,我們獲得了自定義數據對象,在向用戶返回自定義數據之前,deepCopy方法將被調用,
         * 它將根據自定義數據對象構造一個完全拷貝,并將此拷貝返回給用戶使用。
         * 此時,我們就得到了自定義數據對象的2個版本,第一個是從數據庫讀出的原始版本,其二是我們通過deepCopy構造的
         * 復制版本,原始版本將由Hibernate負責維護,復制版本將由用戶使用,原始版本用作稍后的臟數據檢查一句;Hibernate
         * 將在臟數據檢查過程中將這2個版本的數據進行比對,如果數據發生了變化,則執行對應的持久化操作。
         * 數據發生了變化,則執行對應的持久化操作。
         
    */
        
    public Object deepCopy(Object value)throws HibernateException;
        
    /**
         * 本類型實例是否可變
         
    */
        
    public boolean isMutable();
    }

    posted on 2009-10-16 15:59 王永慶 閱讀(161) 評論(0)  編輯  收藏 所屬分類: HIBERNATE
    <2009年10月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(1)

    隨筆分類

    隨筆檔案

    關注blogs

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲第一二三四区| 自拍偷自拍亚洲精品被多人伦好爽 | 久久亚洲AV永久无码精品| 免费观看四虎精品成人| 亚洲人成色77777在线观看大| 国产亚洲综合视频| 亚洲 自拍 另类小说综合图区| 国产产在线精品亚洲AAVV| 亚洲av无码不卡私人影院| 成人免费观看男女羞羞视频| 怡红院亚洲怡红院首页| 成全视频高清免费观看电视剧| 亚洲电影国产一区| 免费可以看黄的视频s色| 亚洲色大成网站WWW国产| 免费在线黄色网址| 中国国语毛片免费观看视频| 亚洲视频在线一区| 国产又黄又爽又猛免费app| 久久久久亚洲AV无码去区首| 亚洲一区二区三区免费| 91久久青青草原线免费| 国产成人亚洲合集青青草原精品| 免费的涩涩视频在线播放| 一级毛片免费毛片毛片| 亚洲一区精品中文字幕| 亚洲精品自在线拍| 免费黄色网址入口| 久久久WWW免费人成精品| 亚洲男人电影天堂| 国产精品另类激情久久久免费| 国产一精品一av一免费爽爽| 亚洲综合最新无码专区| 91禁漫免费进入| 在线观看亚洲网站| 亚洲国产精品久久久久久| 啊灬啊灬别停啊灬用力啊免费看| 老司机69精品成免费视频| 亚洲国产精品自在自线观看| 亚洲国产一成人久久精品| 成年女人毛片免费播放视频m|