MySQL中的autocommit

mysql中提供数据库事物支持的引擎为InnoDB,autocommit在InnoDB数据表中才会生效。

因此,在InnoDB表中,所有的语句都需要开启事物(start transaction)并且commit之后,才会在真实的数据库中生效。

在默认的情况下,autocommit是开启状态的,即使没有手动的使用start transaction开启事物,mysql会默认的将操作当作事物并且提交。

如果用户手动开启了事物(start transaction),那么mysql会把start transaction和commit之间的语句当作一次事物来处理,但是默认并不会帮用户提交,即commit,需要用户手动提交。如果用户不提交便退出,事物将进行回滚。

当把autocommit设置为off时,系统默认的还是会自动开启事物,只不过不会默认提交事物。因此,我们需要手动执行commit。

你可能感兴趣的:(MySQL)