hibernate mysql 序列配置_在MySQL和Hibernate中使用序列

小编典典

您在Mysql中没有序列,但是可以使用’TABLE’id生成

@javax.persistence.TableGenerator(

name="EMP_GEN",

table="GENERATOR_TABLE",

pkColumnName = "key",

valueColumnName = "hi"

pkColumnValue="EMP",

allocationSize=20

)

@Entity

public class Klass {

@Id

@GeneratedValue(strategy = GenerationType.TABLE, generator=EMP_GEN)

@Column(name = "ID")

private Long id;

}

您可能需要@javax.persistence.TableGenerator [...]在所有实体中添加代码段

编辑

非常感谢。但是,我们是否可以使用另一种方式而不将其添加到每个实体中?当在数据库上创建表时,如何为DBMS声明ID主键列以自动生成类似的值?–

napoleonit76

不幸的是,我不知道执行此操作的优雅方法:(.。在我的项目中,我们在多个实体中使用一个序列,并且需要在每个类中声明该序列。您可以尝试做一件事(但是我不会(真的很喜欢)是为您所有实体创建一个超类,并且该超类仅包含ID字段和注释。我有在项目中看到过这种感觉的感觉,但我不确定100%确定。

关于告诉数据库使用该策略,我认为这是不可能的。您可以尝试添加触发器并将其应用于架构中的每个表。当您在表中插入新行,从 生成器表中

选择一个值并将其添加到该行时,触发器将触发。老实说,我不知道这是否行得通,如果您有2个并发会话创建行,则我99%确信这将行不通。

您是否可以重新考虑策略,并使用常规的自动递增列作为ID,并将序列号放在表的另一列中?

2020-06-20

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值