- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这种非标准情况,我需要在 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/
我有一个只读的文本框,但想回发它的值。之前我将代码设置为: /asp:TextBox> 它不工作。我删除了 ReadOnly="true" 并在代码中添加了以下行 txtContractStartDa
一些背景 因此,我正在完成一个 Web 应用程序的一些增强功能,该应用程序可以对数据进行一些自动插值。用户填写了一些文本框,它们之间的其他文本框具有自动计算的值。接收自动计算值的文本框必须是只读的,以
我刚刚审查了一些代码,注意到有人将成员标记为 readonly private。这与 private readonly 有任何不同吗? 例子: readonly private MyClass myI
我刚刚被告知 readonly ref readonly 现在是有效的 C#,我可以清楚地看到它作为面试问题的用途,但除此之外,它什么时候可以用于现实生活? 最佳答案 当您有一个可变结构时,您希望其中
当我使用以下命令运行我的Reactjs + ElectronJS应用程序时,它可以很好地运行: yarn start 。 当我尝试使用以下命令生成该错误时: yarn build 。 我不明白这是怎么
例子1 private const string _DefaultIconPath = _IconsPath + "default.ico"; private const string _IconsP
尝试访问 RecipeList.js 和 Recipe.js 的 .props 时出现语法错误。 这是 Recipe.js 的代码示例: import React, {Component} from
我是 Vue 新手。我正在尝试开发一个聊天应用程序,其中好友列表将显示在左侧菜单上,聊天框将显示在正文中。我正在使用 ajax 调用加载好友列表,并根据好友 ID 路由到聊天框。这是代码示例。
我是 SharePoint 的初学者开发人员,我一直使用 Google map 。我安装了 google-maps-react 但有一个错误告诉我。我不知道如何解决它...请让我知道这个解决方案...
我不确定我是否理解 IE 在我正在使用的脚本中的行为。这是我正在使用的脚本的一部分,它似乎在 Chrome 中运行良好 $(document).keydown(function (event) {
我对原生 react 完全陌生。 我有以下组件: 播放列表: export default class Playlists extends Component { playlists = [
所以我正在使用 MVC3 生成一个文本区域元素。我使用以下标记生成我的元素: model.Description, new { value=Model.Description, @class="re
我有一个从 php 文件创建的表单,以及一个具有只读属性的文本字段,在单击编辑按钮时(编辑按钮也在创建输入字段期间创建),我希望所述字段是可编辑,我该怎么做? value= readOnly>
我正在尝试输入组件的属性并同时使用 URL 参数。我收到以下错误: Property 'match' does not exist on type 'Readonly & Readonly' 这是我的
这个问题在这里已经有了答案: Array.IsReadOnly inconsistent depending on interface implementation (4 个答案) 关闭 8 年前。
根据文档 ( here ),Google 提供了一些相同的范围: https://www.googleapis.com/auth/calendar读/写访问到日历 https://www.google
我使用的是JAWS v2023.2212.23,我有一个div容器,里面有段落和列表。我的要求是,当我专注于div容器时,JAWS应该读取整个块。。对于演示角色,它将只读第一段。。谁能帮我理解所有咏叹
我有一个单选按钮控件,其中有两个项目。 Add A Delete D 我想在条件 X 上仅禁
一、Reactive api 下面我们可以一个例子 如图所示,当我们点击button按钮的时候,是没有响应式效果的,此时我们需要reactive api。 那么这是什么原因呢?为什么就可以变成响应式的
我正在寻找一种在ng-readonly语句中调节ng-if的方法..我尝试了几种方法,这是我的最新建议。 ng-if="note.owner_image === user.image " ng-re
我是一名优秀的程序员,十分优秀!