JDBC的autoCommit为true时,其事务管理测试

本文探讨了JDBC在autoCommit为true时的事务管理。通过测试表明,每个SQL语句执行后都会自动提交,即使在存储过程中也是如此。当存储过程不包含commit时,所有操作不会被提交;而加入commit后,仅执行成功的SQL语句会被提交。
摘要由CSDN通过智能技术生成

前述:事务做为数据库操作特别重要的一方面,不做过多赘述。spring框架使用太久后总忽略一些比较原始的东西,老项目中又使用了这些,看到一些东西总感觉迷惑。比如当使用jdbc调用一个存储过程,该存储过程又有很多子sql语句时,若存储过程出现异常,执行结果如何?猜测会整个回退,但是autoCommit不是自动提交吗?
(jdbc的连接connection默认自动提交autoCommit为ture)
下面就开启探究之旅。。。。。。

测试/验证思路:

1.测试连接获取到之后,进行连续多个CRUD操作,查看操作后期异常和全程无异常的情况。
2.测试连接获取到之后,进行调用存储过程,存储过程中多个CRUD操作(存储过程中无commit语句),查看操作后期异常和全程无异常的情况。
3.测试连接获取到之后,进行调用存储过程,存储过程中多个CRUD操作(存储过程中无commit语句),查看操作后期异常和全程无异常的情况。
此处只为测试,忽略代码是否优美

首先建立测试表,注意两张表的字段长度是不一样的。

create table TEST_LEON_T1(name varchar2(20));
create table TEST_LEON_T2(name varchar2(5));

java代码如下:

public class Test {
    public Connection conn ;
    public static void
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值