【发布时间】:2019-11-15 18:53:39
【问题描述】:
我有一个表,该表维护一个序列号,该序列号用作多个表的标识符(多个发票表,所有表都使用单个序列)。 每当我想在发票表中插入新记录时,我都会从表中读取当前序列号并用 +1 更新它。 问题是当有多个新发票号请求时,序列号会返回重复的数字。我尝试了同步块,但当多个请求同时命中时,它仍然返回重复值。
这里是获取序列号的方法
synchronized public int getSequence(){
Sequence sequence = getCurrentSession().get(Sequence.class,1); //here 1 is the id of the row
int number = sequence.getSequenceNumber();
sequence.setSequenceNumber(number+1);
getCurrentSession().saveOrUpdate(sequence);
return number;
}
我有什么遗漏吗?
【问题讨论】:
-
您应该在单独的事务中获得序列中的下一个数字。但是为了节省更多,请查看
@GeneratedValue(strategy = GenerationType.SEQUENCE) -
synchronized在您的服务器应用程序将运行多个副本时毫无用处。使用正确的事务(Spring 让这变得非常容易)。 -
永远不要手动更新序列。使用 db sewuence、autogenerate 或与 jpa 一起考虑 uuid 作为解决方案(也许是最好的)
-
我的情况不同。序列号在所有三个表上都维护。它对所有3个表都是唯一的。!
-
然后事务T2会因为冲突而回滚,不得不重启。
标签: java spring hibernate synchronized