hibernate 中id生成策略
數據庫的設計和操作中,我們通常會給表建立主鍵。?
主鍵,可以分為自然主鍵和代理主鍵。?
自然主鍵表示:采用具有業務邏輯含義的字段作為表的主鍵。比如在用戶信息表中,采用用戶的身份證號碼作為主鍵。但是這樣一來,隨著業務邏輯的變化,主鍵就有可能要更改。比如,假設哪天身份證號碼升級成19,2位,那。。。。。。。?
代理主鍵:在表中人為的增加一個字段,該字段并沒有表示任何的業務邏輯,僅僅用來標識一行數據。比如說在用戶信息表中,增加一個用戶ID的字段。用來表示該條用戶信息的記錄。?
通常情況下,用的比較多的是代理主鍵的形式。而且,我們習慣于于讓該主鍵字段能夠自動增長,來保證其唯一性。但是,不同的數據庫自動增長的方式并不是相同的。如在SQLSERVER中,用identity,MYSQL中,有increment,ORACLE中通常采用sequence。這樣一來,在數據庫的主鍵列操作上,便會顯得比較麻煩。?
但是在Hibernate中,提供了主鍵生成策略。下面是比較常用的幾種:?
1:assigned?
----表示在新增數據時由應用程序指定主鍵的值。主要針對主鍵是采用自然主鍵的形式。這種方式,適用于主鍵列不是自動增長列。?
其缺點為在執行新增操作時,需查詢數據庫判斷生成的主鍵是否已經存在。?
2:increment?
----表示新增數據操作時由hibernate自動生成主鍵值。其生成的值為:先查詢該主鍵列的最大值,然后在最大值的基礎上加上1.適用于采用代理主鍵形式的主鍵列。同樣不能用于主鍵列是自動增長的表。但是,該主鍵生成策略也有些缺點。?
(1)新增數據前先查詢一遍,影響了性能。?
(2)主鍵的類型只能為數值型的int或者long?
(3)并發操作時的沖突問題。?
3:identity?
----不如說是為sqlerver數據庫量身定做的。主要適用于sqlserver數據庫的自動增長列的表。?
4:native?
----表示根據不同的數據庫采用不同的主鍵生成策略。比如,當前數據庫為sqlserver,則會采用identity,如為oracle,則采用?
oracle中的sequence等。區分數據庫的不同是以hibernate主配置文件中sessionFactory中配置的數據庫方言。?
5.uuid?
* 唯一主鍵生成辦法。從Hibernate中提取出來?
優點:避免了生成ID 時,與數據庫的再次交道,性能上較高。但對于有的開發人員不太習慣這種id生成方式,UUID生成的32為的字符串,不同于identity 從1開始的整數。?
??
Xml代碼?
1.<id name="實體類屬性名" type="java.lang.Integer">???
2.????? <column name="對應表中主鍵字段名" />???
3.????? <generator class="assiged|increment|identity|native|........" />???
4.</id>???
<id name="實體類屬性名" type="java.lang.Integer">?
????? <column name="對應表中主鍵字段名" />?
????? <generator class="assiged|increment|identity|native|........" />?
</id>?
采用hibernate的主鍵生成策略,就可以比較靈活和方便的對表中的主鍵字段進行操作了。而且,不同的數據庫,不同的主鍵形式,也只需要修改下映射文件就可以了
總結
以上是生活随笔為你收集整理的hibernate 中id生成策略的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [基础]iOS 可视化编程(全系列)
- 下一篇: 2066 三角恋