jpa 生成uuid的主键_JPA注解主键生成策略-UUID
@GeneratedValue:主鍵的產(chǎn)生策略,通過(guò)strategy屬性指定。
主鍵產(chǎn)生策略通過(guò)GenerationType來(lái)指定。GenerationType是一個(gè)枚舉,它定義了主鍵產(chǎn)生策略的類型。
1、AUTO 自動(dòng)選擇一個(gè)最適合底層數(shù)據(jù)庫(kù)的主鍵生成策略。如MySQL會(huì)自動(dòng)對(duì)應(yīng)auto increment。這個(gè)是默認(rèn)選項(xiàng),即如果只寫(xiě)@GeneratedValue,等價(jià)于@GeneratedValue(strategy=GenerationType.AUTO)。
2、IDENTITY 表自增長(zhǎng)字段,Oracle不支持這種方式。
3、SEQUENCE 通過(guò)序列產(chǎn)生主鍵,MySQL不支持這種方式。
4、TABLE 通過(guò)表產(chǎn)生主鍵,框架借由表模擬序列產(chǎn)生主鍵,使用該策略可以使應(yīng)用更易于數(shù)據(jù)庫(kù)移植。不同的JPA實(shí)現(xiàn)商生成的表名是不同的,如 OpenJPA生成openjpa_sequence_table表,Hibernate生成一個(gè)hibernate_sequences表,而TopLink則生成sequence表。這些表都具有一個(gè)序列名和對(duì)應(yīng)值兩個(gè)字段,如SEQ_NAME和SEQ_COUNT。
在我們的應(yīng)用中,一般選用@GeneratedValue(strategy=GenerationType.AUTO)這種方式,自動(dòng)選擇主鍵生成策略,以適應(yīng)不同的數(shù)據(jù)庫(kù)移植。
如果使用Hibernate對(duì)JPA的實(shí)現(xiàn),可以使用Hibernate對(duì)主鍵生成策略的擴(kuò)展,通過(guò)Hibernate的@GenericGenerator實(shí)現(xiàn)。
@GenericGenerator(name = “system-uuid”, strategy = “uuid”) 聲明一個(gè)策略通用生成器,name為”system-uuid”,策略strategy為”uuid”。
@GeneratedValue(generator = “system-uuid”) 用generator屬性指定要使用的策略生成器。
這是我在項(xiàng)目中使用的一種方式,生成32位的字符串,是唯一的值。最通用的,適用于所有數(shù)據(jù)庫(kù)。
總結(jié)
以上是生活随笔為你收集整理的jpa 生成uuid的主键_JPA注解主键生成策略-UUID的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 2019.3.1版本Pycharm的使用
- 下一篇: 2019.3.1版本pycharm撤销及