• Mr.钧👻
    2019-02-14
    老师,如果带事务的方法A,循环调用带事务的方法B, 并且在方法B中有try catch 代码, 当B中出现异常,并且被捕获,会报事务嵌套异常. 这个时候我应该怎么选择事务的传播级别呢? 对应业务需求是: 方法B中出现异常,方法B要回滚, 并且把异常返回方法A, 但是不能影响方法A的循环调用. 解决方案应该是在方法B使用NEXTED 事务级别吗?

    作者回复: B可以是NESTED也可以是REQUIRES_NEW,要看你需要什么样的行为。那B正常的,但A回滚了,这时B要回滚么?如果要回滚就是前者,不然后者

    
     13
  • zhangwei
    2019-03-06
    老师您好,有个问题提问下:
    如果在方法上不加Transactional注解,方法中有多条SQL,那么每执行一个SQL会打开一个连接吗,还是所有SQL用一个连接但开启多个事务呢,谢谢。

    作者回复: 没有@Transactional注解,就是没加事务,大部分情况下就是各条SQL单独的事务,比如一条upate语句。假设你用JdbcTemplate来做操作,就会从DataSource里获取连接。有事务的时候,就会用当前事务的连接来做操作。

    
     8
  • 小白
    2019-04-04
    老师,这个事务的传播特性可以详细讲一下么?使用场景什么的
    
     4
  • 豌豆逸之
    2019-09-15
    老师您好,请问事务和jdbc连接池中的连接是什么关系?一个事务有n个sql,是占用n个连接还是一个连接?

    作者回复: 事务是在连接上的,一个事务开启后的多条SQL都是执行在这个连接上的,不会更换连接。

    
     2
  • mumu
    2019-06-08
    老师您好,mysql的可重复读通过gap lock 解决幻读。如果是mysql数据库,spring 的隔离级别设置为3,请问这样会出现幻读吗?

    作者回复: 你都说隔离级别设置为3是,事务隔离级别没有3啊。
    ISOLATION_DEFAULT = -1;
    ISOLATION_READ_UNCOMMITTED = 1;
    ISOLATION_READ_COMMITTED = 2;
    ISOLATION_REPEATABLE_READ = 4;
    ISOLATION_SERIALIZABLE = 8;

     1
     2
  • Marvelous.
    2019-09-12
    老师你好,我在Jpa中使用Transcational注解并设置了传播特性为NESTED,但是运行的时候抛出JpaDialect not support savepoints-check.your JPA providers's capabilities.不支持savepoint,我想问问这个trasactional注解使用的驱动是在哪里配置的呢?应该配置为什么呢?

    作者回复: 这个是根据底层的JPA实现来的,Hibernate不支持NESTED。HibernateTransactionManager这个类的注释里有提到过

    
     1
  • 曾经蜡笔没有小新
    2019-02-13
    require_new和nested有什么区别吗?

    作者回复: 有几位同学都问到了,我答疑时统一解答吧

    
     1
  • 研究员
    2019-12-11
    老师您好,请问funcA()调用funcB(),给funcB()开启一个新事务,当funcA()出错回滚也会回滚funcB(),请问这个怎么解决? 我想要的效果是funcA()的事务不要影响到funcB()的执行。

    作者回复: 如果用的是REQUIRES_NEW,funcA的事务和funcB的事务应该是独立的,funcB提交了,funcA回滚是不影响funcB的。

    
    
  • godtrue
    2019-09-16
    没有原理呀😄老师后面会有原理的讲解嘛?如果不讲原理,付费的价值就没有体现点啦!
    
    
  • 极客海
    2019-08-28
    老师,这里spring和数据库的隔离级别有区别吗?

    作者回复: 是一样的

    
    
  • ck
    2019-04-29
    请问为什么把jdbc hibernate mybatis 放在一起, 而dataSource 和JPA 放在一起?

    作者回复: 抱歉,只是一个个列一下,放一行有点长,没有特殊含义。如果一定要说当时为什么我是这么换行的,上面3个都是可以用来操作数据库的,实实在在的类库或者框架,下面2个属于其他。

    
    
  • 田佩
    2019-02-16
    老师您好,我有个问题想请教下:
    在业务中用到了jdbc和hibernate,如果使用默认的事务配置,可以在一个带有事务的方法中用两种方法操作了同一数据吗?如果用jdbc查询加悲观锁,然后用hibernate能操作这个数据吗?

    作者回复: 其实不用JDBC操作,如果你在线下环境里,用某些客户端连上数据库,select for update锁住某条记录,你的程序在尝试锁定同一条记录时都会卡住或者报错。

    
    
我们在线,来聊聊吧