程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 常用Hibernate主鍵生成策略

常用Hibernate主鍵生成策略

編輯:關於JAVA

今天學習到了關於Hibernate主鍵生成策略的問題,總結下,不足之處,請大家指出。

Hibernate為優秀的持久層框架的代表。在傳統的JDBC+JavaBean操作中,實體對象都由程序員自己去封裝,然後返回。而在Hibernate中,采用對象關系映射『ORM』,大大簡化了對數據庫的操作.

在數據庫的設計和操作中,我們通常會給表建立主鍵。主鍵,可以分為自然主鍵和代理主鍵。

自然主鍵表示:采用具有業務邏輯含義的字段作為表的主鍵。比如在用戶信息表中,采用用戶的身份證號碼作為主鍵。但是這樣一來,隨著業務邏輯的變化,主鍵就有可能要更改。比如,假設哪天身份證號碼升級成19,2位,那。。。。。。。

代理主鍵:在表中人為的增加一個字段,該字段並沒有表示任何的業務邏輯,僅僅用來標識一行數據。比如說在用戶信息表中,增加一個用戶ID的字段。用來表示該條用戶信息的記錄。

通常情況下,用的比較多的是代理主鍵的形式。而且,我們習慣於於讓該主鍵字段能夠自動增長,來保證其唯一性。但是,不同的數據庫自動增長的方式並不是相同的。如在SQLSERVER中,用identity,MYSQL中,有increment,ORACLE中通常采用sequence。這樣一來,在數據庫的主鍵列操作上,便會顯得比較麻煩。

但是在Hibernate中,提供了Hibernate主鍵生成策略。下面是比較常用的幾種:

1:assigned

表示在新增數據時由應用程序指定主鍵的值。主要針對主鍵是采用自然主鍵的形式。這種方式,適用於主鍵列不是自動增長列。

其缺點為在執行新增操作時,需查詢數據庫判斷生成的主鍵是否已經存在。

2:increment

表示新增數據操作時由hibernate自動生成主鍵值。其生成的值為:先查詢該主鍵列的最大值,然後在最大值的基礎上加上1.適用於采用代理主鍵形式的主鍵列。同樣不能用於主鍵列是自動增長的表。但是,該主鍵生成策略也有些缺點。

(1)新增數據前先查詢一遍,影響了性能。

(2)主鍵的類型只能為數值型的int或者long

(3)並發操作時的沖突問題。

3:identity

不如說是為sqlerver數據庫量身定做的。主要適用於sqlserver數據庫的自動增長列的表。

4:native

表示根據不同的數據庫采用不同的Hibernate主鍵生成策略。比如,當前數據庫為sqlserver,則會采用identity,如為oracle,則采用

oracle中的sequence等。區分數據庫的不同是以hibernate主配置文件中sessionFactory中配置的數據庫方言。

Xml代碼

<id name="實體類屬性名" type="java.lang.Integer">
       <column name="對應表中主鍵字段名" />
       <generator class="assiged|increment|identity|native|........" />
</id>

采用hibernate主鍵生成策略,就可以比較靈活和方便的對表中的主鍵字段進行操作了。而且,不同的數據庫,不同的主鍵形式,也只需要修改下映射文件就可以了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved