欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java探索之Hibernate主鍵生成策略詳細介紹

 更新時間:2017年10月25日 08:45:33   作者:不知不覺已變淡  
這篇文章主要介紹了Java探索之Hibernate主鍵生成策略詳細介紹,具有一定參考價值,需要的朋友可以了解下。

1.increment

     由Hibernate從數(shù)據(jù)庫中去除主鍵的最大值(每個session只取一次),以該值為基礎,每次增量為1,在內(nèi)存中生成主鍵,不依賴于底層的數(shù)據(jù)庫,因此可以跨數(shù)據(jù)庫。

<id name="id" column="id">
<generator class="increment" />
</id>

Hibernate調(diào)用org.hibernate.id.IncrementGenerator類里面的generate()方法,使用select max(idColumnName) from tableName語句獲取主鍵最大值。該方法被聲明成了synchronized,所以在一個獨立的Java虛擬機內(nèi)部是沒有問題的,然而,在多個JVM同時并發(fā)訪問數(shù)據(jù)庫select max時就可能取出相同的值,再insert就會發(fā)生Dumplicate entry的錯誤。所以只能有一個Hibernate應用進程訪問數(shù)據(jù)庫,否則就可能產(chǎn)生主鍵沖突,所以不適合多進程并發(fā)更新數(shù)據(jù)庫,適合單一進程訪問數(shù)據(jù)庫,不能用于群集環(huán)境。

特點:跨數(shù)據(jù)庫,不適合多進程并發(fā)更新數(shù)據(jù)庫,適合單一進程訪問數(shù)據(jù)庫,不能用于群集環(huán)境。

2.sequence

采用數(shù)據(jù)庫提供的sequence機制生成主鍵,需要數(shù)據(jù)庫支持sequence。如oralce、DB、SAP DB、PostgerSQL、McKoi中的sequence。MySQL這種不支持sequence的數(shù)據(jù)庫則不行(可以使用identity)。

<generator class="sequence">
<param name="sequence">hibernate_id</param>
</generator>

<param name="sequence">hibernate_id</param> 指定sequence的名稱

Hibernate生成主鍵時,查找sequence并賦給主鍵值,主鍵值由數(shù)據(jù)庫生成,Hibernate不負責維護,使用時必須先創(chuàng)建一個sequence,如果不指定sequence名稱,則使用Hibernate默認的sequence,名稱為hibernate_sequence,前提要在數(shù)據(jù)庫中創(chuàng)建該sequence。

特點:只能在支持序列的數(shù)據(jù)庫中使用,如Oracle。

3.identity

identity由底層數(shù)據(jù)庫生成標識符。identity是由數(shù)據(jù)庫自己生成的,但這個主鍵必須設置為自增長,使用identity的前提條件是底層數(shù)據(jù)庫支持自動增長字段類型,如DB2、SQL Server、MySQL、Sybase和HypersonicSQL等,Oracle這類沒有自增字段的則不支持。

<id name="id" column="id">
<generator class="identity" />
</id>

例:如果使用MySQL數(shù)據(jù)庫,則主鍵字段必須設置成auto_increment。
id int(11) primary key auto_increment

特點:只能用在支持自動增長的字段數(shù)據(jù)庫中使用,如MySQL。

4.native

    native由hibernate根據(jù)使用的數(shù)據(jù)庫自行判斷采用identity、hilo、sequence其中一種作為主鍵生成方式,靈活性很強。如果能支持identity則使用identity,如果支持sequence則使用sequence。

<id name="id" column="id">
<generator class="native" />
</id>

例如MySQL使用identity,Oracle使用sequence
注意:如果Hibernate自動選擇sequence或者hilo,則所有的表的主鍵都會從Hibernate默認的sequence或hilo表中取。并且,有的數(shù)據(jù)庫對于默認情況主鍵生成測試的支持,效率并不是很高。
使用sequence或hilo時,可以加入?yún)?shù),指定sequence名稱或hi值表名稱等,如
<param name="sequence">hibernate_id</param>

    特點:根據(jù)數(shù)據(jù)庫自動選擇,項目中如果用到多個數(shù)據(jù)庫時,可以使用這種方式,使用時需要設置表的自增字段或建立序列,建立表等。

5.uuid

    UUID:Universally Unique Identifier,是指在一臺機器上生成的數(shù)字,它保證對在同一時空中的所有機器都是唯一的。按照開放軟件基金會(OSF)制定的標準計算,用到了以太網(wǎng)卡地址、納秒級時間、芯片ID碼和許多可能的數(shù)字,標準的UUID格式為:

xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx (8-4-4-4-12)

其中每個 x 是 0-9 或 a-f 范圍內(nèi)的一個十六進制的數(shù)字。

<id name="id" column="id">
<generator class="uuid" />
</id>

Hibernate在保存對象時,生成一個UUID字符串作為主鍵,保證了唯一性,但其并無任何業(yè)務邏輯意義,只能作為主鍵,唯一缺點長度較大,32位(Hibernate將UUID中間的“-”刪除了)的字符串,占用存儲空間大,但是有兩個很重要的優(yōu)點,Hibernate在維護主鍵時,不用去數(shù)據(jù)庫查詢,從而提高效率,而且它是跨數(shù)據(jù)庫的,以后切換數(shù)據(jù)庫極其方便。

    特點:uuid長度大,占用空間大,跨數(shù)據(jù)庫,不用訪問數(shù)據(jù)庫就生成主鍵值,所以效率高且能保證唯一性,移植非常方便,推薦使用。

6.guid

    GUID:Globally Unique Identifier全球唯一標識符,也稱作 UUID,是一個128位長的數(shù)字,用16進制表示。算法的核心思想是結(jié)合機器的網(wǎng)卡、當?shù)貢r間、一個隨即數(shù)來生成GUID。從理論上講,如果一臺機器每秒產(chǎn)生10000000個GUID,則可以保證(概率意義上)3240年不重復。

<id name="id" column="id">
<generator class="guid" />
</id>

Hibernate在維護主鍵時,先查詢數(shù)據(jù)庫,獲得一個uuid字符串,該字符串就是主鍵值,該值唯一,缺點長度較大,支持數(shù)據(jù)庫有限,優(yōu)點同uuid,跨數(shù)據(jù)庫,但是仍然需要訪問數(shù)據(jù)庫。

注意:長度因數(shù)據(jù)庫不同而不同

MySQL中使用select uuid()語句獲得的為36位(包含標準格式的“-”)
Oracle中,使用select rawtohex(sys_guid()) from dual語句獲得的為32位(不包含“-”) 

    特點:需要數(shù)據(jù)庫支持查詢uuid,生成時需要查詢數(shù)據(jù)庫,效率沒有uuid高,推薦使用uuid。

7.foreign

    使用另外一個相關聯(lián)的對象的主鍵作為該對象主鍵。主要用于一對一關系中。

<id name="id" column="id">
<generator class="foreign">
<param name="property">user</param>
</generator>
</id>
<one-to-one name="user" class="domain.User" constrained="true" />

該例使用domain.User的主鍵作為本類映射的主鍵。

特點:很少使用,大多用在一對一關系中。

總結(jié)

以上就是本文關于Java探索之Hibernate主鍵生成策略詳細介紹的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Hibernate實現(xiàn)悲觀鎖和樂觀鎖代碼介紹、詳細解讀Hibernate的緩存機制等,有什么問題可以隨時留言,歡迎交流討論。感謝朋友們對本站的支持!

相關文章

  • java中堆內(nèi)存與棧內(nèi)存的知識點總結(jié)

    java中堆內(nèi)存與棧內(nèi)存的知識點總結(jié)

    在本篇文章里小編給大家整理的是關于java中堆內(nèi)存與棧內(nèi)存的知識點總結(jié),有需要的朋友們可以跟著學習下。
    2019-12-12
  • Springboot配置返回日期格式化五種方法詳解

    Springboot配置返回日期格式化五種方法詳解

    本文主要介紹了Springboot配置返回日期格式化五種方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • Java?對象在?JVM?中的內(nèi)存布局超詳細解說

    Java?對象在?JVM?中的內(nèi)存布局超詳細解說

    這篇文章主要介紹了Java?對象在?JVM?中的內(nèi)存布局超詳細解說,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • java對同一個文件進行讀寫操作方法

    java對同一個文件進行讀寫操作方法

    在本篇文章里我們給大家詳細講述了java對同一個文件進行讀寫操作的方法和知識點,需要的朋友們可以參考學習下。
    2018-10-10
  • 基于jni調(diào)用時,jvm報錯問題的深入分析

    基于jni調(diào)用時,jvm報錯問題的深入分析

    本篇文章是對jni調(diào)用時,jvm的報錯問題進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • Java并發(fā)編程之閉鎖與柵欄的實現(xiàn)

    Java并發(fā)編程之閉鎖與柵欄的實現(xiàn)

    這篇文章主要介紹了Java并發(fā)編程之閉鎖與柵欄的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • Intellij IDEA神器居然還有這些小技巧

    Intellij IDEA神器居然還有這些小技巧

    Intellij IDEA真是越用越覺得它強大,它總是在我們寫代碼的時候,不時給我們來個小驚喜,本文給大家主要介紹一些你可能不知道的但是又實用的小技巧,感興趣的朋友跟隨小編一起看看吧
    2021-01-01
  • JAVA8獨有的map遍歷方式(非常好用)

    JAVA8獨有的map遍歷方式(非常好用)

    這篇文章主要介紹了JAVA8獨有的map遍歷方式(非常好用),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Java日常練習題,每天進步一點點(60)

    Java日常練習題,每天進步一點點(60)

    下面小編就為大家?guī)硪黄狫ava基礎的幾道練習題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-08-08
  • Java 如何獲取url地址文件流

    Java 如何獲取url地址文件流

    這篇文章主要介紹了Java 如何獲取url地址文件流,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07

最新評論