mysql事务中使用临时表

本文探讨了在使用存储过程进行数据汇总时遇到的问题,即在MySQL中使用CREATE TABLE或DROP TABLE语句会自动提交事务,即便之后发生错误并尝试回滚。文章详细介绍了测试过程及结果,并指出使用临时表时这一行为的不同。

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

转载于:https://www.cnblogs.com/sdlz/p/9061144.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值