Hibernate的generator屬性
Hibernate的generator屬性
- 本文講述Hibernate的generator屬性的意義。Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。
- <class name="onlyfun.caterpillar.User"
- table="USER">
- <id name="id" type="string" unsaved-value="null">
- <column name="USER_ID"/>
- <generator class="uuid.hex"/>
- </id>
- </class>
- <id name="id" column="id">
- < generator class="identity"/>
- </id>
- <id name="id" column="id">
- <generator class="sequence">
- <param name="sequence">序列名</param>
- </generator>
- </id>
- <id name="id" column="id">
- <generator class="native"/>
- </id>
- <id name="id" column="id">
- <generator class="hilo">
- <param name="table">high_val</param>
- <param name="column">nextval</param>
- <param name="max_lo">5</param>
- </generator>
- </id>
- <id name="id" column="id">
- <generator class="hilo">
- <param name="sequence">high_val_seq</param>
- <param name="max_lo">5</param>
- </generator>
- </id>
- <id name="id" column="id">
- <generator class="assigned"/>
- </id>
- <generator class="sequence"/>
- <class name="onlyfun.caterpillar.User" table="USER">
- <id name="id" type="string" unsaved-value="null">
- <column name="USER_ID"/>
- <generator class="uuid.hex"/>
- </id>
- </class>
Hibernate的Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。
1、identity:用于MySql數據庫。特點:遞增
注:對于MySql數據庫使用遞增序列時需要在建表時對主鍵指定為auto_increment屬性。
2、sequence:用于Oracle數據庫
3、native:跨數據庫時使用,由底層方言產生。
Default.sequence為hibernate_sequence
注:使用native時Hibernate默認會去查找Oracle中的hibernate_sequence序列。
如果Oracle中沒有該序列,連Oracle數據庫時會報錯。
4、hilo:通過高低位合成id,先建表hi_value,再建列next_value。必須要有初始值。
5、sequencehilo:同過高低位合成id,建一個sequence序列,不用建表。
6、assigned:用戶自定義id;
7、foreign:用于一對一關系共享主健時,兩id值一樣。
本文講解Hibernate中hbm的generator子元素的一些內置生成器的快捷名字。Generator子元素是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現。
在*.hbm.xml必須聲明的< generator>子元素是一個Java類的名字,用來為該持久化類的實例生成唯一的標識。
這是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現。當然,Hibernate提供了很多內置的實現。下面是Generator子元素的一些內置生成器的快捷名字:
increment(遞增)
用于為long, short或者int類型生成唯一標識。只有在沒有其他進程往同一張表中插入數據時才能使用。 在集群下不要使用。
identity
對DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的內置標識字段提供支持。返回的標識符是long, short 或者int類型的。
sequence (序列)
在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的標識符是long, short或者 int類型的。
hilo (高低位)
使用一個高/低位算法來高效的生成long, short或者 int類型的標識符。給定一個表和字段(默認分別是是hibernate_unique_key 和next_hi)作為高位值得來源。高/低位算法生成的標識符只在一個特定的數據庫中是唯一的。在使用JTA獲得的連接或者用戶自行提供的連接中,不要使用這種生成器。
seqhilo(使用序列的高低位)
使用一個高/低位算法來高效的生成long, short或者 int類型的標識符,給定一個數據庫序列(sequence)的名字。
uuid.hex
用一個128-bit的UUID算法生成字符串類型的標識符。在一個網絡中唯一(使用了IP地址)。UUID被編碼為一個32位16進制數字的字符串。
uuid.string
使用同樣的UUID算法。UUID被編碼為一個16個字符長的任意ASCII字符組成的字符串。不能使用在PostgreSQL數據庫中
native(本地)
根據底層數據庫的能力選擇identity, sequence 或者hilo中的一個。
assigned(程序設置)
讓應用程序在save()之前為對象分配一個標示符。
foreign(外部引用)
使用另外一個相關聯的對象的標識符。和< one-to-one>聯合一起使用。
Generator子元素的用法:
posted on 2012-06-19 17:54 何云隆 閱讀(1659) 評論(0) 編輯 收藏 所屬分類: Hibernate