Hibernate的generator屬性

Hibernate的generator屬性

標籤: generatorhibernateclasspostgresql數據庫oracle
22561人閱讀 評論(1) 收藏 舉報
分類:
    本文講述Hibernate的generator屬性的意義。Generator屬性有7種class,本文簡略描述了這7種class的意義和用法。
    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的意義和用法。javascript

    一、identity:用於MySQL數據庫。特色:遞增 css

    1. <id name="id" column="id">  
    2. < generator class="identity"/>  
    3. </id>  

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

    二、sequence:用於Oracle數據庫 java

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

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

    1. <id name="id" column="id">  
    2. <generator class="native"/>  
    3. </id>   

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

    四、hilo:經過高低位合成id,先建表hi_value,再建列next_value。必需要有初始值。sql

    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>    

    五、sequencehilo:同太高低位合成id,建一個sequence序列,不用建表。 數據庫

    [c-sharp] view plain copy
    print ?
    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>   

    六、assigned:用戶自定義id; api

    1. <id name="id" column="id">   
    2. <generator class="assigned"/>  
    3. </id>   

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

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

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

    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子元素的用法:

    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>  

4
0
 
 
相關文章
相關標籤/搜索