表生成器(@TableGenerator)使用注意事项

用途:将当前主键的值单独保存到数据库的一张表里去,主键的值每次都是从该表中查询获得,适用于任何数据库,不必担心兼容问题。

常规配置,看下面例子:

@Id

@Column(name = "id")

@TableGenerator(name = "hf_opert_id_gen", //此处的名字要和下面绿色标注的对应

table = "mcs_hibernate_seq", //主键保存到数据库的表名

pkColumnName = "sequence_name", //表里用来保存主键名字的字段

valueColumnName = "sequence_next_hi_value",//表里用来保存主键值的字段

pkColumnValue = "user_id", //表里名字字段对应的值

allocationSize = 1)//自动增长,设置为1

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

private Integer id;

运行后,表mcs_hibernate_seq的结构如下:

注意该表的结构,只有两列,如果你需要给该表再加一列主键id的话,务必要记得设置为自增

同时该实体类对应的数据库表的主键id不能设置为自增,不然会报错的。

每当从这张主键表获取对应的主键值后,该值会自动更新+1,为下一次赋值做好了准备。

转载于:https://my.oschina.net/6tao/blog/76283

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值