【解决问题】Transaction was marked for rollback only; cannot commit

文章讨论了在导入文件时遇到的TransactionException,指出事务被标记为只回滚,无法提交。原因在于代码中虽然捕捉了异常,但未抛出,导致事务注解失效。解决方法是确保在适当位置抛出异常以保持事务功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题现象:

导入文件的时候直接报错:

Transaction was marked for rollback only; cannot commit; nested exception is org.hibernate.TransactionException: Transaction was marked for rollback only; cannot commit

中文意思大概是:事务是进行回滚的,不能直接提交

原因分析:

1.代码截图如下:

 2.代码分析:

事务是执行数据库插入等动作的时候,出现异常进行回滚的,也就是必须发生异常 ,捕捉到异常才行,仔细查看代码,try...catch 已经捕捉异常了,但是并没有进行异常抛出,那么事务注解就没有任何意义。

根据分析,去掉try...catch,重新测试,不在出现错误

3.原因

添加事务注解后,不能捕捉异常或者捕捉异常需要在抛出,不然事务注解没有意义

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值