Hibernate的generator屬性

  • 本文講述Hibernate的generator屬性的意義。Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。
[xhtml] view plaincopy
  1. <class name="onlyfun.caterpillar.User"  
  2. table="USER">   
  3. <id name="id" type="string" unsaved-value="null">   
  4. <column name="USER_ID"/>   
  5. <generator class="uuid.hex"/>  
  6. </id>   
  7. </class>   
   

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

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

[xhtml] view plaincopy
  1. <id name="id" column="id">  
  2. < generator class="identity"/>  
  3. </id>  

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

2、sequence:用於Oracle數據庫

[xhtml] view plaincopy
  1. <id name="id" column="id">  
  2. <generator class="sequence">  
  3. <param name="sequence">序列名</param>  
  4. </generator>  
  5. </id>   

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

[xhtml] view plaincopy
  1. <id name="id" column="id">  
  2. <generator class="native"/>  
  3. </id>   

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

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

[xhtml] view plaincopy
  1. <id name="id" column="id">  
  2. <generator class="hilo">  
  3. <param name="table">high_val</param>  
  4. <param name="column">nextval</param>  
  5. <param name="max_lo">5</param>  
  6. </generator>  
  7. </id>    

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

[c-sharp] view plaincopy
  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;

[xhtml] view plaincopy
  1. <id name="id" column="id">   
  2. <generator class="assigned"/>  
  3. </id>   

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

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

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

[xhtml] view plaincopy
  1. <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子元素的用法:

[xhtml] view plaincopy
  1. <class name="onlyfun.caterpillar.User" table="USER">  
  2. <id name="id" type="string" unsaved-value="null">  
  3. <column name="USER_ID"/>  
  4. <generator class="uuid.hex"/>  
  5. </id>  
  6. </class>  

發佈了28 篇原創文章 · 獲贊 21 · 訪問量 17萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章