亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

JSP 中Hibernate實現映射枚舉類型

2024-09-05 00:22:56
字體:
來源:轉載
供稿:網友

JSP 中Hibernate實現映射枚舉類型

問題:

Java BO類Gender是枚舉類型,想在數據庫中存成字符串格式,如何編寫hbm.xml?

public enum Gender{   UNKNOWN("Unknown"),   MALE("Male"),   FEMALE("Female");     private String key;  private Gender(final String key) {   this.key = key;  }  public getGender(String key) {   for (Gender gender : Gender.values()) {    if (key.euqals(gender.getKey()))     return gender;         }   throw new NoSuchElementException(key);  } } 

使用UserType:

public class GenderUserType implements UserType {     private static int[] typeList = { Types.VARCHAR};    /*   * Return the SQL type codes for the columns mapped by this type.   * The codes are defined on <tt>java.sql.Types</tt>. */  /**設置和Gender類的sex屬性對應的字段的SQL類型 */   public int[] sqlTypes() {    return typeList;  }   /*The class returned by <tt>nullSafeGet()</tt>.*/  /** 設置GenderUserType所映射的Java類:Gender類 */  public Class returnedClass() {    return Gender.class;   }    /** 指明Gender類是不可變類 */   public boolean isMutable() {    return false;  }   /*  * Return a deep copy of the persistent state, stopping at entities and at  * collections. It is not necessary to copy immutable objects, or null  * values, in which case it is safe to simply return the argument.  */  /** 返回Gender對象的快照,由于Gender類是不可變類, 因此直接將參數代表的Gender對象返回 */   public Object deepCopy(Object value) {    return (Gender)value;   }    /** 比較一個Gender對象是否和它的快照相同 */  public boolean equals(Object x, Object y) {   //由于內存中只可能有兩個靜態常量Gender實例,    //因此可以直接按內存地址比較    return (x == y);   }   public int hashCode(Object x){     return x.hashCode();   }    /*  * Retrieve an instance of the mapped class from a JDBC resultset. Implementors  * should handle possibility of null values.  */  /** 從JDBC ResultSet中讀取key,然后返回相應的Gender實例 */  public Object nullSafeGet(ResultSet rs, String[] names, Object owner)                throws HibernateException, SQLException{     //從ResultSet中讀取key    String sex = (String) Hibernate.STRING.nullSafeGet(rs, names[0]);     if (sex == null) { return null; }     //按照性別查找匹配的Gender實例     try {      return Gender.getGender(sex);     }catch (java.util.NoSuchElementException e) {      throw new HibernateException("Bad Gender value: " + sex, e);     }   }   /*  * Write an instance of the mapped class to a prepared statement. Implementors  * should handle possibility of null values.  * A multi-column type should be written to parameters starting from <tt>index</tt>.  */  /** 把Gender對象的key屬性添加到JDBC PreparedStatement中 */  public void nullSafeSet(PreparedStatement st, Object value, int index)                  throws HibernateException, SQLException{    String sex = null;    if (value != null)      sex = ((Gender)value).getKey();    Hibernate.String.nullSafeSet(st, sex, index);   }    /*  * Reconstruct an object from the cacheable representation. At the very least this  * method should perform a deep copy if the type is mutable. (optional operation)  */  public Object assemble(Serializable cached, Object owner){    return cached;  }     /*    * Transform the object into its cacheable representation. At the very least this    * method should perform a deep copy if the type is mutable. That may not be enough    * for some implementations, however; for example, associations must be cached as    * identifier values. (optional operation)   */   public Serializable disassemble(Object value) {      return (Serializable)value;    }    /*  * During merge, replace the existing (target) value in the entity we are merging to  * with a new (original) value from the detached entity we are merging. For immutable  * objects, or null values, it is safe to simply return the first parameter. For  * mutable objects, it is safe to return a copy of the first parameter. For objects  * with component values, it might make sense to recursively replace component values.  */  public Object replace(Object original, Object target, Object owner){     return original;   }  } 

然后再hbm.xml中定義映射關系:

<hibernate-mapping package="" default-lazy="true" default-cascade="save-update,merge,persist">   <typedef name="Gender" class="com.alpha.hibernate.GenderUserType">     <property name="gender" type="Gender">         <column name="GENDER" not-null="true">         </column>     </property> 

延伸:

為每個枚舉類型定義一個UserType是比較麻煩的,可以定義一個抽象類。

例如擴展下例即可適用于所有保存為index的枚舉類型

public abstract class OrdinalEnumUserType<E extends Enum<E>> implements UserType {     protected Class<E> clazz;      protected OrdinalEnumUserType(Class<E> clazz) {     this.clazz = clazz;   }      private static final int[] SQL_TYPES = {Types.NUMERIC};    public int[] sqlTypes() {      return SQL_TYPES;    }      public Class<?> returnedClass() {      return clazz;    }      public E nullSafeGet(ResultSet resultSet, String[] names, Object owner)                 throws HibernateException, SQLException {          //Hibernate.STRING.nullSafeGet(rs, names[0])     int index = resultSet.getInt(names[0]);     E result = null;      if (!resultSet.wasNull()) {        result = clazz.getEnumConstants()[index];      }      return result;    }      public void nullSafeSet(PreparedStatement preparedStatement,      Object value,int index) throws HibernateException, SQLException {      if (null == value) {        preparedStatement.setNull(index, Types.NUMERIC);      } else {        //Hibernate.String.nullSafeSet(st, sex, index);       preparedStatement.setInt(index, ((E)value).ordinal());      }    }      public Object deepCopy(Object value) throws HibernateException{      return value;    }      public boolean isMutable() {      return false;    }      public Object assemble(Serializable cached, Object owner)  throws HibernateException {      return cached;   }     public Serializable disassemble(Object value) throws HibernateException {      return (Serializable)value;    }      public Object replace(Object original, Object target, Object owner) throws HibernateException {      return original;    }    public int hashCode(Object x) throws HibernateException {      return x.hashCode();    }    public boolean equals(Object x, Object y) throws HibernateException {      if (x == y)        return true;      if (null == x || null == y)        return false;      return x.equals(y);    }  } 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的


注:相關教程知識閱讀請移步到JSP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一免费网站| 欧美精品福利视频| 不卡av电影院| 欧美精品一本久久男人的天堂| 日韩最新中文字幕电影免费看| 欧美黑人又粗大| 国产一区二区三区视频免费| 欧美大片大片在线播放| 亚洲精品影视在线观看| 国产99久久精品一区二区| 日韩欧美国产一区二区| 欧美日韩在线另类| 亚洲欧美一区二区激情| 国产午夜精品免费一区二区三区| 国产精品白丝jk喷水视频一区| 成人免费视频网| 91精品国产91久久| 欧美片一区二区三区| 日韩中文字幕在线免费观看| 日韩禁在线播放| 日韩成人中文字幕在线观看| 久久视频免费观看| 国产精品嫩草影院一区二区| 亚洲成人中文字幕| 亚洲欧美国内爽妇网| 91黑丝高跟在线| 国产精品igao视频| 色噜噜狠狠狠综合曰曰曰88av| 亚洲视频视频在线| 日本一区二区不卡| 91九色国产社区在线观看| 中文字幕亚洲天堂| 亚洲国产欧美精品| 国产精品久久久久久婷婷天堂| 欧美与欧洲交xxxx免费观看| 精品综合久久久久久97| 日韩亚洲一区二区| 91性高湖久久久久久久久_久久99| 日韩精品一二三四区| 亚洲亚裔videos黑人hd| 91在线免费观看网站| 亚洲人成电影在线观看天堂色| 色婷婷**av毛片一区| 久久久成人精品| 色99之美女主播在线视频| 91久久精品久久国产性色也91| 日韩人体视频一二区| 久久久国产视频91| 91在线免费观看网站| 日韩美女免费视频| 国产乱人伦真实精品视频| 日本中文字幕不卡免费| 日韩乱码在线视频| 欧美巨猛xxxx猛交黑人97人| 国产91精品视频在线观看| 国产精品mp4| 日韩在线观看成人| 国产精品jizz在线观看麻豆| 国产精品中文字幕久久久| 亚洲国产欧美久久| 久久精品国产v日韩v亚洲| 精品人伦一区二区三区蜜桃免费| 精品国产91久久久| 欧美国产日韩一区二区在线观看| 97视频在线观看视频免费视频| 欧美在线视频观看免费网站| 国产欧美精品在线| 国产亚洲精品美女久久久久| 欧美高清videos高潮hd| 久久久免费在线观看| 国产日产欧美精品| 91亚洲永久免费精品| 久久久影视精品| 亚洲女在线观看| 亚洲精品视频中文字幕| 国产精品电影网| 国产精品爽黄69天堂a| 精品国产欧美一区二区五十路| 成人在线免费观看视视频| 欧美性极品xxxx娇小| 国产一区视频在线播放| 久久久精品国产一区二区| 高清日韩电视剧大全免费播放在线观看| 欧美性视频网站| 日韩在线精品一区| 国产一区二区三区日韩欧美| 日韩专区中文字幕| 亚洲天堂网站在线观看视频| 精品久久久久久国产| 国产性猛交xxxx免费看久久| 日韩电影免费在线观看| 亚洲最大成人网色| 国产视频999| 亚洲免费精彩视频| 久久精品电影网站| 色综合老司机第九色激情| 日韩福利视频在线观看| 精品人伦一区二区三区蜜桃免费| 一区二区三区精品99久久| 成人黄色网免费| 色播久久人人爽人人爽人人片视av| 亚洲国产一区二区三区在线观看| 欧美精品18videos性欧美| 国产精品丝袜白浆摸在线| 亚洲午夜激情免费视频| 麻豆一区二区在线观看| 亚洲黄色免费三级| 亚洲欧美一区二区三区在线| 亚洲男女自偷自拍图片另类| 亚洲欧美精品在线| 亚洲国产成人爱av在线播放| 欧美激情一级精品国产| 欧美日韩xxxxx| 国产亚洲精品一区二区| 欧美成人午夜视频| 国产精品美女主播在线观看纯欲| 欧美视频一区二区三区…| 亚洲国产中文字幕久久网| 亚洲视频欧洲视频| 在线视频中文亚洲| 日韩电影在线观看中文字幕| 精品色蜜蜜精品视频在线观看| 国产精品久久久久久亚洲影视| 久久全球大尺度高清视频| 久久av在线播放| 亚洲成人精品在线| 成人黄色免费片| 国产精品1234| 好吊成人免视频| 九九九久久久久久| 亚洲四色影视在线观看| 亚洲天堂男人天堂女人天堂| 91精品一区二区| 免费99精品国产自在在线| 欧美亚洲视频在线看网址| 国产一区视频在线| 欧美视频一区二区三区…| 欧美乱大交xxxxx另类电影| 欧美日韩国产二区| 亚洲福利小视频| 久久久国产91| 2019亚洲男人天堂| 国产999在线观看| 少妇高潮久久77777| 成人黄色激情网| 亚洲一区二区三区xxx视频| 成人春色激情网| 国产精品久久久久久久久免费看| 18性欧美xxxⅹ性满足| 成人黄色大片在线免费观看| 亚洲视频在线视频| 国产精品一区二区三区毛片淫片| 91免费视频网站| 国产精品入口福利| 亚洲男子天堂网| 亚洲xxxx做受欧美| 亚洲精品一区二区三区婷婷月| 亚洲福利视频网| 亚洲区免费影片| 国产乱人伦真实精品视频| 日韩欧美在线视频观看| 欧美黄色三级网站| 欧美性猛交xxxx免费看| 欧美午夜www高清视频|