MySQL中的autocommit

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

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值