目前我有三个表:公司,集团,人.
公司连接的三个表是一对多的Group,Group是一对多的Person.
在所有三个类(Company.java,Group.java,Person.java)中,我用这种方式编写了自动增量唯一ID:
@Id @Column(name = "id") @GeneratedValue private int id;
然后我按此顺序实例化所有三个类:Company,Group,Person.
将这些对象保存到我的数据库后,我注意到表中的id有问题.
显然,而不是按顺序1,2,3,4等增加公司的ID; 它在1,4,7,10增加......
在同样的逻辑中,Group的id为2,5,8,11 ......
我该怎么做才能防止@GeneratedValue计数器在三个不同的表之间共享?我应该使用其他或不同的标签吗?
谢谢.
这可能是因为hibernate为id序列生成了一个表.你在和哪个DB合作?MySQL的?或其他不使用序列的数据库?您可以尝试使用:
@GeneratedValue(strategy = GenerationType.IDENTITY)