文章目录
一. 长事务原因
1. set autocommit=0
- 这个命令会关闭当前线程的事务自动提交功能
- 意味着如果只执行一个 select 语句,这个事务就启动了,并且不会自动提交。
这个事务持续存在直到主动执行 commit 或 rollback 语句,或者断开连接。如果是长连接,就导致了长事务。
- 有些客户端连接框架会默认连接成功后先执行一个 set autocommit=0 的命令。这就导致接下来的查询都在事务中,如果是长连接,就导致了长事务。
- 所以建议使用【set autocommit=1】, 通过显式语句的方式来启动事务。
2. 事务方法业务复杂,执行时间长
二. 长事务危害
1. 占用大量的存储空间
- 在 MySQL 中,实际上每条记录在更新的时候都会同时记录一条回滚操作。记录更新前的值,通过回滚操作,就可以得到前一个状态的值。
- 这些记录下来的回滚操作就是回滚段,长事务意味着系统里面会存在很老的回滚段。由于这些事务随时可能访问数据库里面的任何数据,所以这个事务提交之