<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-9  評論-168  文章-266  trackbacks-0
          1)increment 代理主鍵,hibernate自動以遞增的方式來生成標識符,每次增加1.
          2)identity 代理主鍵,由底層數據庫生成標識符,前提就是底層的數據庫支持自動增長的類型.
          3)sequence 代理主鍵,hibernate根據底層數據庫生成的標識符,前提是底層數據庫支持序列
          4)hilo 代理主鍵,hibernate根據higg/low算法來生成的標識符,把特定表的字段作為high的值,默認選用hibernate_unique_key表的next_hi字段
          5)native 代理主鍵,根據底層數據庫對自動生成標識符的支持能力,還選擇identity,sequence,或hilo.
          6)uuid.hex 代理主鍵,hibernate采用128位的UUID算法生成標識符,UUID算法能夠在網絡環境下生成唯一字符串標識符.不過字符串要比數據占用的空間多的多.所以不流行使用.
          7)assigned 適用于自然主鍵,由JAVA應用程序負責生成標識符,為了能讓JAVA設置OID.不能吧setId方法設置為非公共類型了,這種方式也盡量避免使用.
          這里個人覺得第一種方式,也就是說由Hibernate來生成對象標識符的方式比較好.但是這種方式的缺點是只能一個Hibernate對應一個數據庫的表.當同時創建了SeesionFactory實例的時候.兩個或者更多的Hibernate對應同一個數據庫的時候就會插入出錯.這個時候我們可以選擇第二種方式把標識符的生成工作交給底層數據庫.還有一個小知識點要注意就是OID必須定義為long,int,short類型,如果定義為byte會報異常,這里推薦用long.
          總結一下,這7中生成OID標識符的方法,increment 比較常用,把標識符生成的權力交給Hibernate處理.但是當同時多個Hibernate應用操作同一個數據庫,甚至同一張表的時候.就推薦使用identity 依賴底層數據庫實現,但是數據庫必須支持自動增長,sequence 以來底層數據庫實現,但是數據庫必須支持系列.hilo 根據特定的表實現.這三種方式了.當然針對不同的數據庫選擇不同的方法.如果你不能確定你使用的數據庫具體支持什么的情況下.可以選擇第三種.或者用native 讓Hibernate來幫選擇identity,sequence,或hilo.后邊的自然主鍵不推薦使用,因為自然主鍵就是具有業務含義的主鍵,在現在的軟件開發結構中,已經很少有人用了.下面總結一下幾種常用數據庫,可以使用的標識符類型.
          MySQL:identity數據庫底層實現,需要支持自動增長,increment由Hibernate實現,hilo用特定的表實現,
          MSSQL:identity數據庫底層實現,需要支持自動增長,increment由Hibernate實現,hilo用特定的表實現,
          Oracle:sequence數據庫底層實現,需要支持序列,increment由Hibernate實現,hilo用特定的表實現,
          以上不難發現,所有的數據庫都支持Hibernate用increment實現OID的生成,MYSQL和MSSQL數據庫底層實現支持自動增長,而Oracle支持序列,還有用特殊表的實現方式這三個數據庫都支持.還有一種實現方式適用于所有的數據庫,就是native,由Hibernate去選擇使用什么樣的方式來生成IOD對象標識符,這種方式也是跨平臺的.

                                                                                         --------------摘自:http://www.tkk7.com/action/archive/2007/05/22/119134.html
    posted on 2008-03-19 12:11 紫蝶∏飛揚↗ 閱讀(338) 評論(0)  編輯  收藏 所屬分類: Hibernate
    主站蜘蛛池模板: 男女免费观看在线爽爽爽视频 | 成年人视频在线观看免费| 香蕉视频在线观看亚洲| 二个人看的www免费视频| 久久激情亚洲精品无码?V| 永久免费无码日韩视频| 浮力影院亚洲国产第一页| 久久成人永久免费播放| 亚洲熟妇无码乱子AV电影| 三级网站在线免费观看| 亚洲AV无码不卡在线播放| 亚欧免费无码aⅴ在线观看| 亚洲综合小说久久另类区| 免费视频专区一国产盗摄| 亚洲人片在线观看天堂无码| 国产色婷婷精品免费视频| 一级做a爰片久久毛片免费陪| 日本亚洲国产一区二区三区| 久久国产乱子精品免费女| 亚洲视频网站在线观看| 免费观看黄网站在线播放| 国产亚洲视频在线| 亚洲精品二区国产综合野狼| 99re在线精品视频免费| 一本色道久久88—综合亚洲精品 | 成年18网站免费视频网站| 国产精品国产亚洲区艳妇糸列短篇| 免费中文字幕在线| 久久久精品免费国产四虎| 亚洲永久在线观看| 亚洲国产午夜中文字幕精品黄网站| 暖暖免费在线中文日本| 亚洲中文字幕无码一去台湾| 亚洲精品和日本精品| 亚洲电影在线免费观看| 色屁屁www影院免费观看视频| 久久亚洲精品国产精品黑人| 噜噜嘿在线视频免费观看| 丝袜足液精子免费视频| 在线精品亚洲一区二区| 亚洲毛片αv无线播放一区 |