希望有人能指出正确的方向,说明为什么这不起作用:
Session session = factory.openSession();
session.refresh(customer);
session.close();
Boolean paid = customer.hasPaid();
if (paid) {
System.out.println("test1");
} else {
System.out.println("test2");
}
if (!paid && paymentInput.getRequestType() == PaymentInput.RequestType.NEW) {
session = factory.openSession();
Transaction tx = session.beginTransaction();
customer.setPaid(true);
customer.update(customer, customer.getId());
tx.commit();
session.close();
System.out.println("updated");
PaymentProcessor.pay(customer);
}
我想要的是第一个请求命中“test2”,然后是“更新”,所有其他请求命中“test1”并错过第二个条件。如果我在彼此之后快速触发多个请求,目前它会点击“test1”并多次进入第二个条件。我在这里做错了什么?
最佳答案
其他测试不命中“test1”的唯一方法是让它们在第 16 行之后开始它们的交易——tx.commit();
——已经完成了它的工作。你的目标是什么?如果您的请求必须假设事务已提交,您将不得不强制它们等待,直到该假设成立。这通常是通过某种锁来完成的。
关于java - 在 Hibernate 中处理竞争条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44831279/