一般在大项目上,有些公司会禁止用这个@Transactional 声明式注解,进而改成编程式事务。
因为这个声明式事务存在以下一些问题:
- 在方法上增加@Transaction 声明式事务,如果一个方法中的存在较多耗时操作, 就容易引发长事务问题,而长事务会带来锁的竞争影响性能,同时也会导致数据库 连接池被耗尽,影响程序的正常执行。
- 如果方法存在嵌套调用,而被嵌套调用的方法也声明了@Transaction 事务,就会 出现事务的嵌套调用行为,容易引起事务的混乱造成程序运行结果出现异常
- @Transaction 声明式事务是将事务控制逻辑放在注解中,如果项目的复杂度增加, 事务的控制可能会变得更加复杂,导致代码可读性和维护性下降。
所以,为了避免这类问题,有些公司会推荐使用编程式事务,这样可以更加灵活地控制 事务的范围,减少事务的锁定时间,提高系统的性能。