同事遇见一个事务回滚的问题,从controller提交的时候出现,transaction marked as rollbackonly 这个错误。
从调用栈上来看,没啥可用的信息,另外基本没有啥用户代码,都是框架JPA的代码
这个事其实以前遇见过类似的,所以先排查出现过异常的,但是这个祖传代码调用非常的深,根本不是单步调试可以的(估摸着几百个调用),利用IDEA工具准备说是一点JPDA的特性,十分钟之内找到异常点了。
不要问我为什么没有打印出异常,因为异常被吞了。
原因大概是这样的:
关键点如图所示
就是这玩意引起了事务的回滚。
解决办法嘛,也很简单,conatins方法判断的对象必须要是实体类或者是 HibernateProxy类似的,如果从这个角度,肯定怕有所遗漏出新的BUG,但是可以反过来判断,如果这个类的包是特定的包,并且这个类上没有@Entity,把这个拔除,然后就OK了