Hibernate的generator屬性的意義

 

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. <idname="id"column="id">

  2. <generatorclass="hilo">

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

  4. <paramname="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類的名字,用來爲該持久化類的實例生成唯一的標識。

<  generator class="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"/>

  5. <  /id>

 

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