一共是13種,其中包括native
native: 對於 oracle 采用 Sequence 方式,對於MySQL 和 SQL Server 采用identity(自增主鍵生成機制),native就是將主鍵的生成工作交由數據庫完成,hibernate不管(很常用)。 uuid: 采用128位的uuid算法生成主鍵,uuid被編碼為一個32位16進制數字的字符串。占用空間大(字符串類型)。 hilo: 使用hilo生成策略,要在數據庫中建立一張額外的表,默認表名為hibernate_unique_key,默認字段為integer類型,名稱是next_hi(比較少用)。 assigned: 在插入數據的時候主鍵由程序處理(很常用),這是 <generator>元素沒有指定時的默認生成策略。等同於JPA中的AUTO。 identity: 使用SQL Server 和 MySQL 的自增字段,這個方法不能放到 Oracle 中,Oracle 不支持自增字段,要設定sequence(MySQL 和 SQL Server 中很常用)。 等同於JPA中的INDENTITY。 select: 使用觸發器生成主鍵(主要用於早期的數據庫主鍵生成機制,少用)。 sequence: 調用底層數據庫的序列來生成主鍵,要設定序列名,不然hibernate無法找到。 seqhilo: 通過hilo算法實現,但是主鍵歷史保存在Sequence中,適用於支持 Sequence 的數據庫,如 Oracle(比較少用) increment: 插入數據的時候hibernate會給主鍵添加一個自增的主鍵,但是一個hibernate實例就維護一個計數器,所以在多個實例運行的時候不能使用這個方法。 foreign: 使用另外一個相關聯的對象的主鍵。通常和<one-to-one>聯合起來使用。 guid: 采用數據庫底層的guid算法機制,對應MYSQL的uuid()函數,SQL Server的newid()函數,ORACLE的rawtohex(sys_guid())函數等。 uuid.hex: 看uuid,建議用uuid替換。 sequence-identity: sequence策略的擴展,采用立即檢索策略來獲取sequence值,需要JDBC3.0和JDK4以上(含1.4)版本
hibernate提供了多種生成器供選擇,基於Annotation的方式通過@GenericGenerator實現.
hibernate每種主鍵生成策略提供接口org.hibernate.id.IdentifierGenerator的實現類,如果要實現自定義的主鍵生成策略也必須實現此接口.
1、identity:用於MySql數據庫。
特點:遞增
< id name="id" column="id">
< generator class="identity"/>
< /id>
注:對於MySql數據庫使用遞增序列時需要在建表時對主鍵指定為auto_increment屬性。
2、sequence:用於Oracle數據庫
< id name="id" column="id">
< generator class="sequence">
< param name="sequence">序列名< /param>
< /generator>
< /id>
3、native:跨數據庫時使用,由底層方言產生。
Default.sequence為hibernate_sequence
< id name="id" column="id">
< generator class="native"/>
< /id>
注:使用native時Hibernate默認會去查找Oracle中的hibernate_sequence序列。
如果Oracle中沒有該序列,連Oracle數據庫時會報錯。
4、hilo:通過高低位合成id,先建表hi_value,再建列next_value。必須要有初始值。
< id name="id" column="id">
< generator class="hilo">
< param name="table">high_val< /param>
< param name="column">nextval< /param>
< param name="max_lo">5< /param>
< /generator>
< /id>
5、sequencehilo:同過高低位合成id,建一個sequence序列,不用建表。
< id name="id" column="id">
< generator class="hilo">
< param name="sequence">high_val_seq< /param>
< param name="max_lo">5< /param>
< /generator>
< /id>
6、assigned:用戶自定義id;
< id name="id" column="id">
< generator class="assigned"/>
< /id>
7、foreign:用於一對一關系共享主健時,兩id值一樣。
貌似還會有increament如下:
主鍵產生器
可選項說明:
1) Assigned
主鍵由外部程序負責生成,無需Hibernate參與。
2) hilo
通過hi/lo 算法實現的主鍵生成機制,需要額外的數據庫表保存主鍵生成歷史狀態。
3) seqhilo
與hilo 類似,通過hi/lo 算法實現的主鍵生成機制,只是主鍵歷史狀態保存在Sequence中,適用於支持Sequence的數據庫,如Oracle。
4) increment
主鍵按數值順序遞增。此方式的實現機制為在當前應用實例中維持一個變量,以保存着當前的最大值,之后每次需要生成主鍵的時候將此值加1作為主鍵。這種方式可能產生的問題是:如果當前有多個實例訪問同一個數據庫,那么由於各個實例各自維護主鍵狀態,不同實例可能生成同樣的主鍵,從而造成主鍵重復異常。因此,如果同一數據庫有多個實例訪問,此方式必須避免使用。
5) identity
采用數據庫提供的主鍵生成機制。如DB2、SQL Server、MySQL中的主鍵生成機制。
6) sequence
采用數據庫提供的sequence 機制生成主鍵。如Oralce 中的Sequence。
7) native
由Hibernate根據底層數據庫自行判斷采用identity、hilo、sequence其中一種作為主鍵生成方式。
8) uuid.hex
由Hibernate基於128 位唯一值產生算法生成16 進制數值(編碼后以長度32 的字符串表示)作為主鍵。
9) uuid.string
與uuid.hex類似,只是生成的主鍵未進行編碼(長度16)。在某些數據庫中可能出現問題(如PostgreSQL)。
10) foreign
使用外部表的字段作為主鍵。一般而言,利用uuid.hex 方式生成主鍵將提供最好的性能和數據庫平台適應。另外由於常用的數據庫,如Oracle、DB2、SQLServer、MySql 等,都提供了易用的主鍵生成機制(AutoIncrease 字段或者Sequence)。我們可以在數據庫提供的主鍵生成機制上,采用generator-class=native的主鍵生成方式。不過值得注意的是,一些數據庫提供的主鍵生成機制在效率上未必最佳,大發insert數據時可能會引起表之間的互鎖。數據庫提供的主鍵生成機制,往往是通過在一個內部表中保存當前主鍵狀態(如對於自增型主鍵而言,此內部表中就維護着當前的最大值和遞增量),之后每次插入數據會讀取這個最大值,然后加上遞增量作為新記錄的主鍵,之后再把這個新的最大值更新回內部表中,這樣,一次Insert操作可能導致數據庫內部多次表讀寫操作,同時伴隨的還有數據的加鎖解鎖操作,這對性能產生了較大影響。因此,對於並發Insert要求較高的系統,推薦采用uuid.hex 作為主鍵生成機制。
3 如果需要采用定制的主鍵產生算法,則在此處配置主鍵生成器,主鍵生成器必須實現net.sf.hibernate.id.IdentifierGenerator 接口。