hibernate id 生成器

hibernate id 生成器

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

    < id name="id" column="id">

       < generator class="identity"/>

    < /id>

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

2sequence:用於Oracle數據庫 

    < id name="id" column="id">

       < generator class="sequence">

      < param name="sequence">序列名< /param>

     < /generator>

  < /id>

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

   < id name="id" column="id">

     < generator class="native"/>

  < /id>

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

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

  < 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>  

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

 < id name="id" column="id">

  < generator class="hilo">

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

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

  < /generator>

  < /id>

6assigned:用戶自定義id; 

   < id name="id" column="id">

   < generator class="assigned"/>

   < /id>

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

本文講解Hibernatehbmgenerator子元素的一些內置生成器的快捷名字。Generator子元素是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現。IDCardStudent形成一對一關聯,IDCard端的設置映射配置如下: 

<class name="IDCard">

        <id name="id" column="Card_id">

           <generator class="foreign">

              <param name="property">student</param>

           </generator>

       </id>      

        <property name="IDNo" unique="true"/>

        <property name="nationality"/>

        <property name="address"/>

        <one-to-one name="student"  class="Student" constrained="true"/>  

</class>

解釋: 

1<generator class="foreign"> 

     指定id生成方式, (之前我們用的id生成方式是native,是讓底層數據庫自動生成id,目前我的應徵環境下,native1開始,遞增生成id)。在這裏,我們要用外鍵來生成主鍵,所以指定爲foreign,也就是去共享關聯對象的主鍵。 

2<param name="property">student</param> 

    指定主鍵來源,這裏的student是關聯名稱。 

3<one-to-one name="student"  class="Student" constrained="true"/>   

     指定與Student形成一對一關聯, 

4constrained=”true” 

該選項最關鍵的是影響savedelete的先後順序 

沒有設定時:總是先操作關聯表,後操作本表; 

設定以後:添加時先關聯表,後本表;刪除時先本表,再操作關聯表。 

  

  

  

*.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_keynext_hi)作爲高位值得來源。高/低位算法生成的標識符只在一個特定的數據庫中是唯一的。在使用JTA獲得的連接或者用戶自行提供的連接中,不要使用這種生成器。 

seqhilo(使用序列的高低位)

使用一個高/低位算法來高效的生成long, short或者 int類型的標識符,給定一個數據庫序列(sequence)的名字。 

uuid.hex

用一個128-bitUUID算法生成字符串類型的標識符。在一個網絡中唯一(使用了IP地址)。UUID被編碼爲一個3216進制數字的字符串。 

uuid.string

使用同樣的UUID算法。UUID被編碼爲一個16個字符長的任意ASCII字符組成的字符串。不能使用在PostgreSQL數據庫中 

native(本地)

根據底層數據庫的能力選擇identity, sequence或者hilo中的一個。 

assigned(程序設置)

讓應用程序在save()之前爲對象分配一個標示符。 

foreign(外部引用)

使用另外一個相關聯的對象的標識符。和< one-to-one>聯合一起使用。 

Generator子元素的用法: 

   <  class name="onlyfun.caterpillar.User" table="USER">

             <  id name="id" type="string" unsaved-value="null">

                 <  column name="USER_ID"/>

                 <  generator class="uuid.hex"/>

            <   /id>  


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