zoukankan      html  css  js  c++  java
  • 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语句则会像官网说的那样自动提交事务。

    凡哥,别他妈吹牛逼了
  • 相关阅读:
    Metroid Prime (Wii) Chs 20100120
    刀削面
    胶水帝
    一种新思维,一个新起点
    MP+
    涂鸦
    Metroid Prime (Wii) Chs 20100117
    Cypress 68013 and UMDF
    Metroid Prime Chs 20091010
    process VS thread
  • 原文地址:https://www.cnblogs.com/sdlz/p/9061144.html
Copyright © 2011-2022 走看看