最近在使用存储过程完成晚上数据的定时汇总功能,其中需要在存储过程中启用事务,但是发现使用了create table语句后事务会自动提交这个语句前的语句,即便是这个语句后发生了错误进行了回滚。
测试语句如下
START TRANSACTION; insert into test_table(name) values('张三'); drop temporary table if exists tmp_table; -- 如果这里替换为 drop table if exists tmp_table同样可以删除临时表,但是会导致事务自动提交 create temporary table tmp_table select * from test_table; ROLLBACK; select * from tmp_table; -- 没有任何数据 select * from test_table; -- 没有任何数据
根据测试总结如下:
如果 drop table 、create table指定了 temporary关键字,手动启动事务中是不会自动提交事务的,否则正常情况的create table ,drop table语句则会像官网说的那样自动提交事务。