標籤:
Hibernate自訂主鍵,通過此方法可以解決一此特殊的主鍵ID,在瞭解自訂主鍵時,先瞭解下Hibernate有內建的10種產生主鍵方法.
1) assigned
主鍵由外部程式負責產生,無需Hibernate參與。
推薦此種方法,在實體配置中修改如下:
<id name="HId" type="java.lang.String"> <column name="H_ID" length="20" /> <generator class="assigned" ></generator> </id>
並建立一個sequence,但是不在上邊的設定檔中綁定。
然後程式中,擷取sequence的最後一個值(http://www.cnblogs.com/koal/p/4304316.html),這樣產生出來的自訂主鍵ID就爽多了。
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方式產生主鍵將提供最好的效能和資料庫平台適應性。
但是Hibernate內建的標識(OID)產生器不足以滿足需求,使用者需要定義自己的對象標識產生器。有人會問Hibernate可以自訂主鍵?答案是肯定的.
Hibernate(3.0)提供的標識產生器擴充相關介面:org.hibernate.id.IdentifierGenerator和org.hibernate.id.Configurable
這裡我們只介紹介面org.hibernate.id.org.hibernate.id.Configurable ,而org.hibernate.id.Configurable 介面大家可以試試
首先自己定義一個類,然後實現org.hibernate.id.Configurable介面
public class GeneralSrid implements IdentifierGenerator {
public Serializable generate(SessionImplementor arg0, Object arg1)
throws HibernateException {
return StrUtil.generalSrid(); // 這裡就是自己自訂的主鍵方法.
}
}
然後找到hibernate的XML檔案,把上面實現的類寫到class屬性,這樣就完成了自訂主鍵
<comment>部門資訊</comment>
<id name="deptid" type="java.lang.String">
<column name="DEPTID" length="32" />
<generator class="GeneralSrid" />
</id>
Hibernate自訂主鍵