- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
A(){
con.begin;
.........
.........
B();
........
........(con.rollback;)
con.commit;
}
B{
con.begin;
.......
.......
con.commit;
}
在上面的代码中,我在 A() 处开始了一个新的数据库事务。它成功执行了一些事务。之后 B() 开始执行,它也成功执行了一些事务,现在控制权返回到 A()。此时发生了一些异常,我进行了回滚。我想知道在 B() 中成功的事务是否会回滚。
最佳答案
简短的回答,不。长答案如下。
Java 中对嵌套事务的支持取决于起作用的各种变量。
首先,如果您使用的是 JTA,则由事务管理器来支持嵌套事务。如果尝试在已与事务关联的线程中启动新事务,则任何启动事务的尝试都可能导致事务管理器(不支持嵌套事务)抛出 NotSupportedException。
来自 Java Transaction API 1.1 规范:
3.2.1 Starting a Transaction
The TransactionManager.begin method starts a global transaction and associates the transaction context with the calling thread. If the Transaction Manager implementation does not support nested transactions, the TransactionManager.begin methodthrowsthe NotSupportedException whenthe calling thread is already associated with a transaction.
JDBC 3.0 引入了 Savepoint类,它或多或少类似于数据库中保存点的概念。必须使用 Connection.setSavepoint() 初始化保存点返回保存点实例的方法。可以在稍后使用 Connection.rollback(Savepoint svpt) 回滚到此保存点。方法。当然,所有这些都取决于您是否使用了支持保存点设置和回滚的 JDBC 3.0 兼容驱动程序。
默认情况下,所有获得的连接都设置为自动提交,除非 JDBC 驱动程序在这方面有明显的偏差。如果启用此功能,则会自动排除嵌套事务的范围,因为通过连接在数据库中所做的所有更改都会在执行时自动提交。
如果您禁用自动提交功能,并选择显式提交和回滚事务,那么提交事务总是会提交连接执行的所有更改,直到该时间点为止。请注意,为提交选择的更改不能由程序员定义 - 在该时刻之前的所有更改都被选择为提交,无论它们是在一种方法还是另一种方法中执行的。唯一的出路是定义保存点,或者破解 JDBC 驱动程序 - 驱动程序通常会提交与线程关联的连接执行的所有更改,因此启动一个新线程(这很糟糕)并在其中获取一个新连接, 通常会为您提供新的事务上下文。
您可能还想检查您的框架如何为嵌套事务提供支持,尤其是当您与 JDBC API 隔离或无法自行启动新的 JTA 事务时。
根据上面关于如何在各种情况下实现嵌套事务支持的描述,您的代码中的回滚似乎将回滚与 Connection 对象关联的所有更改。
关于java - 嵌套事务——回滚场景,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3786568/
我打算使用 vulkan synchronization examples 之一作为如何处理不经常更新的统一缓冲区的引用。具体来说,我正在看这个: vkBeginCommandBuffer(...);
我对 git 的了解有限。 我已经从 master 创建了一个分支 B1,进行了一些编辑并提交到这个分支。 我想从 B1 创建另一个分支 B2,我在 B2 中进行了一些编辑 而且我还想提交 B2(包含
这是我做的 我创建了一个分支 abc。然后我创建了两个文本文件 one.txt 和 two.txt。然后我将它们提交到分支 abc。然后我从分支中删除文件 one.txt 并将这些更改提交到分支。 现
在我的主分支中,我得到了 2 个文件: file1.txt file2.txt 我从那里创建了名为 b1 的新分支。在b1中,我修改了file2.txt,不小心删除了file1.txt(从磁盘中,当我
我是 git 的新手。 我创建了一个分支,进行了更改,现在我想 merge 回 master 以使它们“永久化”。 所以我执行了 git merge 1.2 报告为已经是最新的,在 master 上执
我在一个新团队中,工作方式与我以前习惯的完全不同,我们在功能分支上工作,测试人员会在该功能分支上进行测试,然后我们会运行一个 jenkins 作业在该功能被测试签署时将该功能 merge 到开发中,根
我目前正在学习动态内存管理是如何工作的,更具体地说是 realloc 以及它是如何在函数中完成的。 在下面的程序中,我只是想尝试使用 malloc 在函数 a() 中分配一些数字,然后将它们传递给另一
在 Java 中如何从另一个线程分派(dispatch)回主 UI 线程?我正在使用带有 Runnable 的执行器在主 UI 线程之外做一些工作,并且我有一个接口(interface),以便可以通过
我在 git 中有一个项目,所有的事情都直接在 master 分支上完成,标签被用来标记代码的发布版本。我知道这并不理想,并且一直在查看 git 流程,例如:http://nvie.com/posts
我们有一个相当大的 GIT 存储库,我想删除从未 merge 回 master 的分支。 反过来也很好 - 一种列出在某个时候已 merge 到 master 中的所有分支的方法。 我希望首先获取一个
在 Swift 和 C 之间传递字符串时,我看到一些我不理解的行为。请考虑以下 Swift 函数: func demo() { print("\n\n\n\n")
我以前从未合作过,现在我发现自己需要与其他一些人分享这个项目,即使我将完成 90% 的开发工作。 我在 github 上有一个私有(private)仓库。我用 推送了我的初始源 git push or
我们的项目使用 Gitlab,我们有两个长期存在的分支:dev 和 master,类似于 Git Flow。我们正在使用“merge 提交”方法,它将在主分支中创建一个 merge 提交。 但是,由于
我对自定义 View 的绑定(bind)属性有疑问。该属性绑定(bind)到核心数据实体的 NSArrayController。 问题是这样的: 在我看来,我画了几个矩形。这些矩形的位置保存在核心数据
这对我来说似乎太棘手,无法正确执行此操作。 我有一个TreeMap ,我正在获取其中的子图: public static reqObj assignObj(reqObj vArg, i
我有以下 XAML: 所以,基本上我希望将其中一
我正在使用 Angular js 1.3.4 版本并使用 ui-select。 我正在将复杂的多级 JSON 对象数组绑定(bind)到此 ui-select,它工作正常。因此用户可以在此选择中选择任
我正在使用 WebAPI 构建 API,并且一直在使用 NLog 在整个堆栈中进行日志记录。我的 API 解决方案有两个主要项目,包括: 实现 Controller 和 webapi 东西的网站层本身
在 Git 中,给定 (1) 一个分支 A 和 (2) 一个在过去某个时间从 A 派生的分支 B,然后 merge 回 A,我如何才能找到现在 A 中起源于 B 的所有提交? 目的是确定现在在 A 中
假设我的 Controller 如下所示: public class myController { private MyCustomItem acte; ... // gett
我是一名优秀的程序员,十分优秀!