mysql默认开启auto commit,可以,通过这几个sql查看:
select @@autocommit;
SHOW VARIABLES LIKE '%AUTOCOMMIT%';
SHOW GLOBAL STATUS LIKE '%AUTOCOMMIT%';?
我们可以通过系统变量控制来动态控制session级别autocommit
(set autocommit = 0|1),session级别的用处不大,全局禁用才好。
如何从全局禁用autocommit呢,大多数时候我们不想让mysql自动提交,用程序代码来控制,比如spring的声明式事务。
mysql有一个Cmd-Line&Option file&System Var可以帮助我们实现这样的功能,它就是init_connect。
一个比较好用的设置方法是在mysql的初始化文件my.int里加多一行设置。如我的my.int文件路径是:D:\Program Files\MySQL\MySQL Server 5.1\my.int,打开这个文件,在[mysqld]下面加多一行:init_connect=’SET autocommit=0′,如:
[mysqld] #这个对拥有root权限的用户无效 init_connect='SET autocommit=0' #