gpt4 book ai didi

hibernate - Spring + Hibernate + Postgresql readOnly Transaction,按需保存

转载 作者:行者123 更新时间:2023-11-29 12:14:26 25 4
gpt4 key购买 nike

我有这种非标准情况,我需要在 readOnly Hibernate 事务中更新对象。问题是,我加载了许多其他对象,在该事务中更改它们,但只应保存一个对象,然后回滚。我使用的数据库是 Postgresql 8.4

我不确定我是否正确理解了文档,但是制作了一个服务方法:

@Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW)

应该会导致为该保存明确打开新的 RW 事务。

最主要的是,这是行不通的:

@Transactional(readOnly = true)
public class PersonService {

@Resource(name="sessionFactory")
private SessionFactory sessionFactory;

public void add(Person person){

person.setFirstName("changed its name");
save(person);
}

@Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW)
public void save(Person person) {

Session session = sessionFactory.getCurrentSession();

session.save(person);
session.flush();
}
}

之后我得到

org.springframework.web.util.NestedServletException:请求处理失败;嵌套异常是 org.hibernate.exception.GenericJDBCException:无法执行 JDBC 批量更新

从 Controller 调用“添加”方法。 'add' 处于只读模式,它将 Person 对象传递给 'save' 方法,该方法应打开新事务并保存到 DB。在我的“添加”方法项目中,我加载了许多其他不应保存的“人”对象。我需要该方法为只读的原因是我在代码中加载了更多的对象 :) 回滚它们是我最不想做的事情。

这样可以吗?

最佳答案

事务通常通过为服务接口(interface)生成一个实现来应用(你没有表明你正在实现一个接口(interface),那可能只是你的示例代码?)

无论如何,关键是在那种情况下,简单地调用 save(...) 不会通过包装器,它只是在目标对象上运行方法。您需要从服务注入(inject)对自身 的引用,以便它可以调用自身并应用包装。即:

public class PersonServiceImpl implements PersonService {
PersonService personService;
public void readOnlyMethod() {
// ...
personService.readWriteMethod(...);
}
public void readWriteMethod(...) {
}
}

调用堆栈看起来像这样:

PersonServiceImpl.readWriteMethod(...)
TransactionAroundAdvice.advise(...) // starts/ends new read-write transaction
$Proxy.readWriteMethod(...) // implementing PersonService
PersonServiceImpl.readOnlyMethod(...)
TransactionAroundAdvice.advise(...) // starts/ends read-only transaction
$Proxy.readOnlyMethod(...) // implementing PersonService
ClientCode.doSomethingNotReallyReadOnly(...)

(您所描述的听起来像是在记录某种错误消息,这是我使用 requiresNew 事务标记的地方(尽管在 J2EE 中,但我认为这一点很重要))

关于hibernate - Spring + Hibernate + Postgresql readOnly Transaction,按需保存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8569090/

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