generatedvalue mysql_@GeneratedValue 主键自增

本文详细介绍了JPA和Hibernate中的主键生成策略,包括@TableGenerator、@SequenceGenerator、@GeneratedValue的strategy属性,如TABLE、SEQUENCE、IDENTITY、AUTO等,并通过示例代码展示了每种策略的使用方法。同时,还提到了Hibernate特有的@GenericGenerator以及如何自定义主键生成策略。针对不同的数据库,如MySQL、Oracle、PostgreSQL和Kingbase,文章指出了它们对不同策略的支持情况。
摘要由CSDN通过智能技术生成

一、JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue设定的.这里的@id和@GeneratedValue都是JPA的标准用法, JPA提供四种标准用法,由@GeneratedValue的源代码可以明显看出.

Java代码  fa0597550101e8d96e85210a82987976.png

@Target({METHOD,FIELD})

@Retention(RUNTIME)

public@interfaceGeneratedValue{

GenerationType strategy() defaultAUTO;

String generator() default"";

}

其中GenerationType:

Java代码  fa0597550101e8d96e85210a82987976.png

publicenumGenerationType{

TABLE,

SEQUENCE,

IDENTITY,

AUTO

}

JPA提供的四种标准用法为TABLE,SEQUENCE,IDENTITY,AUTO. TABLE:使用一个特定的数据库表格来保存主键。 SEQUENCE:根据底层数据库的序列来生成主键,条件是数据库支持序列。 IDENTITY:主键由数据库自动生成(主要是自动增长型) AUTO:主键由程序控制。

1、TABLE

Java代码  fa0597550101e8d96e85210a82987976.png

@Id

@GeneratedValue(strategy = GenerationType.TABLE, generator="payablemoney_gen")

@TableGenerator(name ="pk_gen",

table="tb_generator",

pkColumnName="gen_name",

valueColumnName="gen_value",

pkColumnValue="PAYABLEMOENY_PK",

allocationSize=1

)

这里应用表tb_generator,定义为

Sql代码  fa0597550101e8d96e85210a82987976.png

CREATETABLEtb_generator (

id NUMBER NOTNULL,

gen_name VARCHAR2(255) NOTNULL,

gen_value NUMBER NOTNULL,

PRIMARYKEY(id)

)

插入纪录,供生成主键使用,

Sql代码  fa0597550101e8d96e85210a82987976.png

INSERTINTOtb_generator(id, gen_name, gen_value)VALUES(1,PAYABLEMOENY_PK', 1);

在主键生成后,这条纪录的value值,按allocationSize递增。

@TableGenerator的定义:

Java代码  fa0597550101e8d96e85210a82987976.png

@Target({TYPE, METHOD, FIELD})

@Retention(RUNTIME)

public@interfaceTableGenerator {

String name();

String table() default"";

String catalog() default"";

String schema() default"";

String pkColumnName() default"";

String valueColumnName() default"";

String pkColumnValue() default"";

intinitialValue()default0;

intallocationSize()default50;

UniqueConstraint[] uniqueConstraints() default{};

}

其中属性说明: name属性表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中。 table属性表示表生成策略所持久化的表名,例如,这里表使用的是数据库中的“tb_generator”。 catalog属性和schema具体指定表所在的目录名或是数据库名。 pkColumnName属性的值表示在持久化表中,该主键生成策略所对应键值的名称。例如在“tb_generator”中将“gen_name”作为主键的键值 valueColumnName属性的值表示在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加。例如,在“tb_generator”中将“gen_value”作为主键的值 pkColumnValue属性的值表示在持久化表中,该生成策略所对应的主键。例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”。 initialValue表示主键初识值,默认为0。 allocationSize表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。 UniqueConstraint与@Table标记中的用法类似。

2、SEQUENCE

Java代码 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值