Mysql的autocommit使用要点
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操作。