表生成器(@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,为下一次赋值做好了准备。

你可能感兴趣的:(TableGenerator)