gpt4 book ai didi

java - spring和hibernate同步访问数据库的方法

转载 作者:行者123 更新时间:2023-12-02 03:28:29 24 4
gpt4 key购买 nike

我有一个表,它维护一个序列号,该序列号用作多个表的标识符(多个发票表,所有表都使用单个序列)。每当我想在发票表中插入新记录时,我都会从表中读取当前序列号并用+1更新它。问题是,当有多个对新发票编号的请求时,序列号会返回重复的数字。我尝试了同步块(synchronized block),但当多个请求同时命中时,它仍然返回重复的值。

这是检索序列号的方法

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;
}

我有什么遗漏吗?

最佳答案

首先我不会建议您使用序列的表实现。 Explanation why

但是如果你必须这样做 - hibernate 知道如何管理它。 Take a look

还有一件事。我强烈建议您在数据库端实现同步。想象一下,您的应用程序有 2 个实例连接到同一个数据库实例并同时工作。

关于java - spring和hibernate同步访问数据库的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56897963/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com