隨筆-29  評論-5  文章-0  trackbacks-0
          來自于:http://developer.51cto.com/art/200906/132121.htm
          在*.hbm.xml必須聲明的< generator>子元素是一個Java類的名字,用來為該持久化類的實例生成唯一的標識。
          < generator class="sequence"/>

          這是一個非常簡單的接口;某些應用程序可以選擇提供他們自己特定的實現(xiàn)。當然,Hibernate提供了很多內(nèi)置的實現(xiàn)。下面是一些內(nèi)置生成器的快 捷名字:

          increment(遞增)
          用于為long, short或者int類型生成唯一標識。只有在沒有其他進程往同一張表中插入數(shù)據(jù)時才能使用。 在集群下不要使用。

          identity
          對DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的內(nèi)置標識字段提供支持。返回的標識符是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)作為高位值得來源。高/低位算法生成的標識符只在一個特定的數(shù)據(jù)庫中是唯一的。在使用JTA獲得的連接或者用戶自行提供的連接中,不要 使用這種生成器。

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

          uuid.hex
          用一個128-bit的UUID算法生成字符串類型的標識符。在一個網(wǎng)絡中唯一(使用了IP地址)。UUID被編碼為一 個32位16進制數(shù)字的字符串。

          uuid.string
          使用同樣的UUID算法。UUID被編碼為一個16個字符長的任意ASCII字符組成的字符串。不能使用在 PostgreSQL數(shù)據(jù)庫中

          native(本地)
          根據(jù)底層數(shù)據(jù)庫的能力選擇identity, sequence 或者hilo中的一個。

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

          foreign(外部引用)
          使用另外一個相關(guān)聯(lián)的對象的標識符。和< one-to-one>聯(lián)合一起使用。

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

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

           
          <column name="USER_ID"/> 

           
          <generator class="uuid.hex"/> 

          </id>
          posted on 2010-06-07 22:07 豪情 閱讀(157) 評論(0)  編輯  收藏 所屬分類: Hibernate 3
          主站蜘蛛池模板: 安塞县| 罗江县| 义马市| 静海县| 福泉市| 东阳市| 澄迈县| 延津县| 武定县| 丰都县| 类乌齐县| 苏尼特左旗| 竹溪县| 拉萨市| 榕江县| 莒南县| 常熟市| 林甸县| 万全县| 富民县| 桓台县| 吉安市| 游戏| 新邵县| 文化| 东莞市| 河津市| 万州区| 银川市| 石首市| 磐石市| 中山市| 金平| 淮南市| 龙口市| 博白县| 北碚区| 白银市| 平定县| 乌兰察布市| 阳信县|