我的祖国冷知识 我的祖国相关知识
10372023-09-09
很多朋友对于Spring事务在哪几种情况下会失效为什么和mysql为什么不建议有长事物不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
本文目录
在MySQL中,同一个事务可以进行多次更改。事务是一组操作的集合,这些操作被视为一个单独的工作单元,要么全部执行成功,要么全部回滚。
因此,如果在同一个事务中进行多次更改,只有在所有更改都成功提交后,才会将更改应用于数据库。如果其中任何一个更改失败,整个事务将回滚到最初的状态,所有更改都将被撤销。
因此,同一个事务可以进行多次更改,但必须保证所有更改都是可靠的,以确保事务的完整性和一致性。
读语句默认不开启事务,允许脏读的
大概列举几种情况,仅供参考;
1.直接new出来的对象添加事务不起作用,因为只有spring定义的bean才接受事务。
2.由于mysql的引擎用Myisam不支持事务,所以如果使用mysql的myisam引擎的话,事务不起作用。
3.如果@Transaction注解到非public方法上,事务不起作用,这是因为spring的Aop特性。4.如果在当前类中进行内部调用方法,比如在A类中有a方法和b方法,a方法没有加@Transaction,b方法加了@Transaction,在方法a中调用方法b,方法b中的事务也不会生效。这是因为spring在扫描bean的时候会自动为标注了@Transaction注解类生成一个代理类,在有注解方法被调用时,实际上是代理类调用的,代理类在调用之前会开启事务,执行事务操作。但是同类中的方法相互调用,相当于this.b(),此时的b方法并非代理类调用,而是直接通过原有的bean直接调用,所以注解不起作用。
5.异常类型错误,如果抛出的runtimeException事务才会回滚。
6.如果异常被catch到,必须要抛出异常,事务才会回滚。
在MySQL中,不需要显式地关闭数据库连接。一旦完成了对数据库的操作,连接会自动在合适的时机关闭。MySQL的客户端和服务器之间通过TCP/IP或套接字进行通信,连接在执行完查询或事务后会自动释放。
当使用编程语言(如Java、Python、PHP等)来访问MySQL数据库时,通常会使用特定的MySQL库或驱动程序来实现数据库连接和操作。在这些情况下,你需要确保在适当的时候关闭数据库连接。即便如此,一般情况下也可以依赖语言本身的垃圾回收机制来自动关闭连接,因为连接对象离开作用域时会被自动销毁,从而关闭连接。
虽然在MySQL中不需要显式地关闭数据库连接,但是对于长时间运行的应用程序,尤其是在高并发环境下,为了保持数据库资源的有效使用,最好还是确保合理地关闭数据库连接,避免资源的浪费。这可以通过在逻辑上正确管理连接的生命周期来实现,例如在使用完连接后显式地关闭它,或使用连接池等机制来自动管理连接的获取和释放。
关于Spring事务在哪几种情况下会失效为什么,mysql为什么不建议有长事物的介绍到此结束,希望对大家有所帮助。