Mysql的autocommit使用要点

1 篇文章 0 订阅

Mysql的autocommit

Mysql中autocommit默认为1开启状态,即sql语句是自动提交的。一段先后关联的sql语句,前面的部分sql执行成功已被自动提交,如果中间或后面的部分sql出现执行失败的状况,就会导致前后事务不一致,数据出现了不一致的情况。

autocommit 和 start transaction 都是事务相关的命令。
start transaction优先级较高,当运行这个命令之后,只有commit之后,sql命令运行的结果才会真正的有效,rollback之后才会回滚。

当没有运行start transaction命令时, 设置autocommit为0时,也是需要手动commit或rollback的。
只有在开启了autocommit 为0的时候,rollback才有效。

关于关闭mysql autocommit属性及transaction事务相关处理和使用要求

服务端

autocommit会导致事务不一致,破坏数据的一致性,Mysql服务端的autocommit属性,需设置为0关闭。

应用程序

应用程序,需明确使用start transaction开启事务,以commit/rollback结束事务,禁止使用autocommit完成事务。

客户端工具

鉴于mysql数据库上查询操作会锁表的机制,要求DBA及维护人员,在各类运维客户端工具中select查询后,需要即时显式commit提交,以避免锁表影响相关表上的DDL操作。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值