mysql事务中使用临时表

最近在使用存储过程完成晚上数据的定时汇总功能,其中需要在存储过程中启用事务,但是发现使用了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语句则会像官网说的那样自动提交事务。

猜你喜欢

转载自www.cnblogs.com/sdlz/p/9061144.html
今日推荐