gpt4 book ai didi

java - 是否有必要对 catch block 中的事务进行回滚?

转载 作者:搜寻专家 更新时间:2023-10-31 20:14:46 25 4
gpt4 key购买 nike

也许是个愚蠢的问题,但如果 EntityManager.merge() 抛出异常,是否有必要对 catch block 中的事务进行回滚?或者异常本身是否意味着合并将无法工作,以便下次我运行提交时抛出异常的先前更改将不适用?

例子:

public void setPerson(Person person) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("MyLib");
EntityManager em = emf.createEntityManager();
try {
if(!em.getTransaction().isActive()){
em.getTransaction().begin();
}
em.merge(person);
em.getTransaction().commit();
emf.getCache().evict(Person.class); // clear Person cache
} catch (Exception ex){
em.getTransaction().rollback(); // Is this necessary?
} finally {
em.close();
}
}

最佳答案

答案取决于 em.merge(person) 方法的细节和您的数据库驱动程序的实现。

如果该方法只执行一个更新语句,那么 rollback 就是多余的。但是,如果它可能运行多个更新,那么就不是那么清楚了。

我个人会把它放在那里

如果 rollback 被删除并且您的 merge 方法在一些更新完成但其他更新未完成后出错,则关闭数据库连接而不显式 commitrollback 将提交或回滚事务,具体取决于驱动程序的实现。根据javadoc for java.sql.Connection ,行为取决于实现。因此,如果您不回滚自己出错,您可能最终会提交部分更新。

关于java - 是否有必要对 catch block 中的事务进行回滚?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10205210/

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