Hibernate的generator屬性

  • 本文講述Hibernate的generator屬性的意義。Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。

  1. <classname="onlyfun.caterpillar.User"

  2. table="USER">

  3. <idname="id"type="string"unsaved-value="null">

  4. <columnname="USER_ID"/>

  5. <generatorclass="uuid.hex"/>

  6. </id>

  7. </class>

Hibernate的Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。

1、identity:用於MySql數據庫。特點:遞增


  1. <idname="id"column="id">

  2. <generatorclass="identity"/>

  3. </id>


注:對於MySql數據庫使用遞增序列時需要在建表時對主鍵指定爲auto_increment屬性。

2、sequence:用於Oracle數據庫


  1. <idname="id"column="id">

  2. <generatorclass="sequence">

  3. <paramname="sequence">序列名</param>

  4. </generator>

  5. </id>


3、native:跨數據庫時使用,由底層方言產生。
Default.sequence爲hibernate_sequence


  1. <idname="id"column="id">

  2. <generatorclass="native"/>

  3. </id>


注:使用native時Hibernate默認會去查找Oracle中的hibernate_sequence序列。
如果Oracle中沒有該序列,連Oracle數據庫時會報錯。

4、hilo:通過高低位合成id,先建表hi_value,再建列next_value。必須要有初始值。


  1. <idname="id"column="id">

  2. <generatorclass="hilo">

  3. <paramname="table">high_val</param>

  4. <paramname="column">nextval</param>

  5. <paramname="max_lo">5</param>

  6. </generator>

  7. </id>


5、sequencehilo:同過高低位合成id,建一個sequence序列,不用建表。


  1. <id name="id" column="id">  

  2. <generator class="hilo">  

  3. <param name="sequence">high_val_seq</param>  

  4. <param name="max_lo">5</param>  

  5. </generator>  

  6. </id>  


6、assigned:用戶自定義id;


  1. <idname="id"column="id">

  2. <generatorclass="assigned"/>

  3. </id>


7、foreign:用於一對一關係共享主健時,兩id值一樣。

本文講解Hibernate中hbm的generator子元素的一些內置生成器的快捷名字。Generator子元素是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現。

在*.hbm.xml必須聲明的< generator>子元素是一個Java類的名字,用來爲該持久化類的實例生成唯一的標識。


  1. <generatorclass="sequence"/>


這是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現。當然,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子元素的用法:


  1. <classname="onlyfun.caterpillar.User"table="USER">

  2. <idname="id"type="string"unsaved-value="null">

  3. <columnname="USER_ID"/>

  4. <generatorclass="uuid.hex"/>


原文出處 http://blog.csdn.net/zzh87615/article/details/6091655

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章