jpa 生成uuid的主键_JPA注解自动生成主键+UUID

该博客介绍了如何在Java中使用@GeneratedValue和@GenericGenerator注解来自动生成主键。当generator属性设置为'uuid'时,可以为SQL Server数据库创建基于UUID的唯一主键。通过这种方式,可以确保在不同数据库之间移植应用时保持主键生成的一致性和通用性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@GeneratedValue: 这个注解用于自动生成主键,源码如下:

@Target({ElementType.METHOD, ElementType.FIELD})

@Retention(RetentionPolicy.RUNTIME)

public @interface GeneratedValue {

GenerationType strategy() default GenerationType.AUTO;

String generator() default "";

}

一、主键的生产策略由属性  strategy 指定,值由一个枚举 GenerationType 来指定,默认是 AUTO 。

1、AUTO 自动选择一个最适合底层数据库的主键生成策略,如MySQL会自动对应auto increment。

这个是默认选项,即如果只写 @GeneratedValue,等价于@GeneratedValue(strategy=GenerationType.AUTO)。

2、IDENTITY 表自增长字段,Oracle不支持这种方式。--用于支持主键自增长的数据库,如mysql,sqlserver

3、SEQUENCE 通过序列产生主键,这个一般用于 Oracle。

4、TABLE 通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。不同的JPA实现商生成的表名是不同的,如 OpenJPA生成openjpa_sequence_table表,Hibernate生成一个hibernate_sequences表,而TopLink则生成sequence表。这些表都具有一个序列名和对应值两个字段,如SEQ_NAME和SEQ_COUNT。

在我们的应用中,一般选用  @GeneratedValue 这种方式,自动选择主键生成策略,以适应不同的数据库移植。

二、generator 这个属性

我用的sqlserver,如何用自动生产uuid作为表主键???

@Id

@GenericGenerator(name = "user-uuid", strategy = "uuid")

@GeneratedValue(generator = "user-uuid")

@Column(name = "id", nullable = false, length = 64)

public String getId() {

return id;

}

@GenericGenerator注解是hibernate的注解,声明一个主键生成器;

@GeneratedValue 注解的 generator属性指定主键生成器

这是我在项目中使用的一种方式,生成32位的字符串,是唯一的值。最通用的,适用于所有数据库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值