用途:将当前主键的值单独保存到数据库的一张表里去,主键的值每次都是从该表中查询获得,适用于任何数据库,不必担心兼容问题。
常规配置,看下面例子:
@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,为下一次赋值做好了准备。