首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >管理事务的最佳方式

管理事务的最佳方式
EN

Stack Overflow用户
提问于 2009-09-15 07:48:08
回答 3查看 955关注 0票数 1

我有基于JBoss和Hibernate的系统。我需要处理两个长操作。操作可能比事务的超时时间更长。It操作是在两个不同的事务中持久化多个实体。如果出现问题,在此操作过程中,我应该回滚事务的所有更改。

解决这个问题的最好方法是什么?

我认为,最好的方法是将所有操作合并到一个事务中,但这需要设置LOng事务超时,这对我们的系统来说是不可接受的。

在这种情况下更好地管理许多事务。我该怎么做呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-09-15 08:12:22

您是否可以使用JTA服务器(事务协调器)通过XA事务在多个步骤中完成事务?This posting提供了一些对您有用的开放源码事务。

XA transactions允许您执行一系列较小的操作,并一次性提交或回滚这些操作。试着在谷歌上搜索“hibernate xa transactions”。大多数现代关系型数据库管理系统平台(MySQL 5.x、PostgreSQL、SQL Server、Oracle、DB2、Sybase等)支持XA事务。

票数 2
EN

Stack Overflow用户

发布于 2009-09-15 07:56:02

使用一个事务是好的,健壮的,等等。再次尝试说服您的管理员;-)

否则,我会想到:

  • 使用较短的事务来插入较少的行,使用一个标记来表示“”。这可以在现有列中,也可以在新列中(可能在不同的表中?)。
  • 如果有事务回滚,请重试;如果您希望中止整个操作,则可以选择删除具有“未完成”标记的行。
  • 当所有事务都已提交时,您可以打开最后一个事务,只为了将所有行标记为“完成”(例如:update ... where ...)。这应该比完整插入快得多,因此事务应该足够短。
票数 1
EN

Stack Overflow用户

发布于 2009-09-15 15:51:59

我不得不在JPA中做类似的事情(通过hibernate)。我在N个事务中完成了操作,而不是1个大事务。这个操作很少运行--它是一个自动作业--所以没有用户在网页上等待结果。

您预计交易需要多长时间?您希望用户等待多长时间?您希望此操作多久发生一次。也许你的需求不是很清楚。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1425742

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档