在Hibernate中,id
元素的<generator>
子元素用於生成持久化類的物件的唯一識別符號。 Hibernate框架中定義了許多生成器類。
所有的生成器類都實現了org.hibernate.id.IdentifierGenerator
介面。 應用程式員可以通過實現IdentifierGenerator
介面來建立自己的生成器類。 Hibernate框架提供了許多內建的生成器類:
如果沒有使用<generator>
元素,assigned
是預設的生成器策略。在這種情況下,應用程式為物件分配ID
。 例如:
....
<hibernate-mapping>
<class ...>
<id ...>
<generator class="assigned"></generator>
</id>
.....
</class>
</hibernate-mapping>
當沒有其他進程將資料插入此表時,才會生成唯一的ID
。 它生成short
,int
或long
型識別符號。 第一個生成的識別符號通常為1
,然後每次遞增為1
。語法:
....
<hibernate-mapping>
<class ...>
<id ...>
<generator class="increment"></generator>
</id>
.....
</class>
</hibernate-mapping>
它使用資料庫的順序序列。如果沒有定義序列,它會自動建立一個序列。 在Oracle資料庫的情況下,它將建立一個名為HIBERNATE_SEQUENCE
的序列。 在Oracle,DB2,SAP DB,Postgre SQL或McKoi的情況下,它使用序列(sequence),但在interbase
中使用生成器。
語法:
.....
<id ...>
<generator class="sequence"></generator>
</id>
.....
要定義自己的序列,請使用generator
的 param
子元素。
.....
<id ...>
<generator class="sequence">
<param name="sequence">your_sequence_name</param>
</generator>
</id>
.....
它使用高低演算法來生成short
,int
和long
型別的id
。 語法:
.....
<id ...>
<generator class="hilo"></generator>
</id>
.....
它使用標識,序列或希洛取決於資料庫供應商。 語法:
.....
<id ...>
<generator class="native"></generator>
</id>
.....
它用於Sybase,Mysql,MS SQL Server,DB2和Hypersonic SQL以支援id
列。 返回的ID
型別為short
,int
或long
。
它在指定的序列名稱上使用高低演算法。 返回的ID
型別為short
,int
或long
。
它使用128
位UUID
演算法生成id
。 返回的ID
是String
型別,在網路中是唯一的(因為使用了IP)。 UUID
以十六進位制數位表示,長度為32
。
它使用由字串型別的資料庫生成的GUID
。 它適用於MS SQL Server和MySQL。
它使用資料庫觸發器返回主鍵。
它使用另一個關聯物件的id
,主要用於<一對一>關聯。
它使用特殊的序列生成策略。 僅在Oracle 10g驅動程式中支援。