MySQL 默认开启事务自动提交模式,每条 SOL 语句都会被当做一个单独的事务自动执行。但有些情况下,我们需要关闭事务自动提交来保证数据的一致性。
通过命令:SHOW VARIABLES LIKE ‘autocommit’;
1.OFF:关闭状态
结果显示,autocommit 的值是 OFF,表示系统关闭模式。
2.ON:开启状态
结果显示,autocommit 的值是 ON,表示系统开启自动提交模式。
在 MySQL 中,可以使用 SET autocommit 语句设置事务的自动提交模式,语法格式如下:
1、SET autocommit = 0|1|ON|OFF;
SET autocommit=1和SET autocommit=ON:表示开启autocommit自动提交事务
SET autocommit=0和SET autocommit=OFF::表示关闭autocommit自动提交事务
以上修改autocommit 状态的操作在本次ssh连接会话中有效,新开启的会话中将失效,
使mysql中的autocommit 自动提交事务永久关闭,可修改mysql配置文件my.cnf,将autocommit=0或者autocommit=OFF添加:
[mysqld]
autocommit=OFF
或者
[mysqld]
autocommit=0
以上两者添加任意一个即可永久关闭mysql数据库默认的事务提交
然后使用重启命令:service mysqld restart重新启动mysql数据库服务,使用SHOW VARIABLES LIKE 'autocommit';查看autocommit状态即可永久关闭
autocommit =ON 事务开启
当mysql数据库默认的自动提交事务打开的状态下,对数据库进行操作后使用rollback回滚无法恢复操作前的数据
autocommit =OFF 提交事务被关闭,
自动事务被关闭,mysql数据库操作后使用rollback回滚可以进行恢复