JPA中的主鍵生成策略

2021-09-27 11:22:20 字數 1943 閱讀 8944

通過annotation(註解)來對映hibernate實體的,基於annotation的hibernate主鍵標識為@id, 其生成規則由@generatedvalue設定的.這裡的@id和@generatedvalue都是jpa的標準用法。

jpa提供的四種標準用法為table,sequence,identity,auto。

具體說明如下:

identity:主鍵由資料庫(mysql)自動生成(主要是自動增長型)

用法:

@id  

@generatedvalue(strategy =generationtype.identity)

private long custid;

sequence:根據底層資料庫的序列來生成主鍵,條件是資料庫(oracle)支援序列。

用法:

@id  

@generatedvalue(strategy = generationtype.sequence,generator="payablemoney_seq")

@sequencegenerator(name="payablemoney_seq", sequencename="seq_payment")

private long custid;

1

//@sequencegenerator原始碼中的定義

2@target()

3@retention(runtime)

4public @inte***ce

sequencegenerator

auto:主鍵由程式控制

用法:

@id  

@generatedvalue(strategy =generationtype.auto)

private long custid;

table:使用乙個特定的資料庫**來儲存主鍵

用法:

1

@id

2 @generatedvalue(strategy = generationtype.table, generator="payablemoney_gen")

3 @tablegenerator(name = "pk_gen",

4 table="tb_generator",

5 pkcolumnname="gen_name",

6 valuecolumnname="gen_value",

7 pkcolumnvalue="payablemoeny_pk",

8 allocationsize=1 9)

10private

long custid;

1112

13//@tablegenerator的定義:

14@target()

15@retention(runtime)

16public @inte***ce

tablegenerator ;

35}

3637

//這裡應用表tb_generator,定義為 :

38create table tb_generator (

39id number not null,

40 gen_name varchar2(255) not null,

41gen_value number not null,

42primary key(id)

43 )

總結:

JPA中的主鍵生成策略

通過annotation 註解 來對映 hibernate 實體的,基於annotation 的hibernate 主鍵標識為 id,其生成規則由 generatedvalue 設定的.這裡的 id 和 generatedvalue 都是jpa 的標準用法。jpa提供的四種標準用法為 table,s...

JPA 主鍵生成策略

hibernate主鍵標識為 id,其生成規則由 generatedvalue設定的 generatedvalue註解的strategy屬性指定具體的策略基本使用的有四種策略規則 表示自增策略,主鍵由資料庫生成 主要是自動增長型 比如 mysql可以在建立表時宣告 auto increment 來指...

JPA的主鍵生成策略

所謂的主鍵生成策略就是,自動生成主鍵列值的策略 identity id自增長策略。只能用於支援id自增長的資料庫。id identity就是強制使用id自增長策略,只能用於支援id自增長的資料庫 generatedvalue strategy generationtype.identity colu...